文档详情

c语言第八章课后题答案.doc

发布:2017-02-01约7.23千字共17页下载文档
文本预览下载声明
一、第八章习题8(p222-p228),8.1-8.3全做,8.4-8.12中选做四道,8.13-8.19中选做三道,要求给出所选择题目的程序及执行结果。 8-1(1)、 #include stdio.h void Func(int x) { x=20; } int main() { int x=10; Func(x); printf(%d,x); return 0; } 结果: 分析:调用函数时只发生值的传递,形参与实参之间再也没有关系,子函数一旦退出,内部变量就释放空间 (2) #include stdio.h void Func(int b[]) { int j; for(j=0; j4; j++) { b[j]=j; } } int main() { static int a[] = {5,6,7,8},i; Func(a); for(i=0; i4; i++) { printf(%d,a[i]); } return 0; } 结果: 分析:数组传递时向函数传递的是数组的地址值,实参与形参共享空间,在被调函数中对数组进行修改就会造成主函数中的数组也被修改。 8.2(1) int PositiveNum(int a[],int n) { int i,count=0; for(i=0; in; i++) { if(a[i]0) count++; } return count; } (2) void Fib(long f[],int n) { int i; f[0]=0; f[1]=1; for(i=2; in; i++) { f[i]=f[i-1]+f[i-2]; } } (3) #include stdio.h int main() { int a[10],n,max,min,maxPos,minPos; for(n=0; n10; n++) { scanf(%d,a[n]); } max=min=a[0]; maxPos=minPos=0; for(n=0; n10; n++) { if(a[n]max) { max=a[n]; maxPos=n; } else if(a[n]min) { min=a[n]; minPos=n; } } printf(max=%d,pos=%d\n,max,maxPos); printf(min=%d,pos=%d\n,min,minPos); return 0; } 结果: (4) #include stdio.h #define ROW 2 #define COL 3 MultiplyMatrix(int a[ROW][COL],int b[COL][ROW],int c[ROW][ROW]) { int i,j,k; for(i=0; iROW; i++) { for(j=0; jROW; j++) { c[i][j]=0; for(k=0; kCOL; k++) { c[i][j]=c[i][j]+a[i][k]*b[k][j]; } } } } void PrintMatrix(int a[ROW][ROW]) { int i,j; for(i=0; iROW; i++) { for(j=0; jROW; j++) { printf(%6d,a[i][j]); } printf(\n); } } int main() { int a[ROW][COL],b[COL][ROW],c[ROW][ROW],i,j; printf(Input 2*3 matrix a:\n); for(i=0; iROW; i++) { for(j=0; jCOL; j++) { scanf(%d,a[i][j]); } } printf(Input 3*2 matrix b:\n); for(i=0; iCOL; i++) { for(j=0; jROW; j++) { scanf(%d,b[i][j]); } } MultiplyMatrix(a,b,c); printf(Results:\n); PrintMatrix(c); return 0; } 结果: 8-3、 viod DivArray(int pArray[],int n) { int i; for (i=0; in; i++) { pArray[i]/=pArray[0]; } } 错误分析:原代
显示全部
相似文档