c语言第八章课后题答案剖析
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
8.2(1)
int PositiveNum(int a[],int n)
{
int i,count=0;
for(i=0; i<n; i++)
{
if(a[i]>0)count++;
}
returncount;
}wk.baidu.com
(2)
void Fib(long f[],int n)
{
int i;
f[0]=0;
f[1]=1;
int n;
int m;
n=Readscore(score,num); /*接收人数*/
m=FindMax(score,num,n);
printf("最高的成绩:%d\n学号为:%ld\n",score[m],num[m]);
}
int Readscore(int score[], long num[])
8-6、
#include <stdio.h>
#define N 40
int Readscore(int score[], long num[]);
int FindMax(int score[],long num[],int n);
void main()
{
int score[N];
long num[N];
{
static int a[] = {5,6,7,8},i;
Func(a);
for(i=0; i<4; i++)
{
printf("%d",a[i]);
}
return 0;
}
结果:
分析:数组传递时向函数传递的是数组的地址值,实参与形参共享空间,在被调函数中对数组进行修改就会造成主函数中的数组也被修改。
printf("%d",x);
return 0;
}
结果:
分析:调用函数时只发生值的传递,形参与实参之间再也没有关系,子函数一旦退出,内部变量就释放空间
(2)
#include <stdio.h>
void Func(int b[])
{
int j;
for(j=0; j<4; j++)
{
b[j]=j;
}
}
int main()
一、第八章习题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);
{
for(j=0; j<ROW; j++)
{
c[i][j]=0;
for(k=0; k<COL; 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; i<ROW; i++)
{
int i=-1;
do{
i++;
printf("请输入学号:");
scanf("%ld",&num[i]);
printf("请输入成绩:");
scanf("%d",&score[i]);
}while(score[i]>=0 && num[i]>=0);
return i;
}
int FindMax(int score[],long num[],int n)
{
for(j=0; j<COL; j++)
{
scanf("%d",&a[i][j]);
}
}
printf("Input 3*2 matrix b:\n");
for(i=0; i<COL; i++)
{
for(j=0; j<ROW; j++)
{
scanf("%d",&b[i][j]);
}
}
MultiplyMatrix(a,b,c);
for(i=2; i<n; 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; n<10; n++)
{
scanf("%d",&a[n]);
}
max=min=a[0];
{
int i;
int k;
int max=score[0];
for(i=0; i<n; i++)
{
if(score[i]>max)
{
max=score[i];
k=i;
}
}
return k;
}
结果:
8-7
#include <stdio.h>
void Sort(int score[]);
void Readscore(int score[]);
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; i<ROW; i++)
void main()
{
int score[10];
Readscore(score);
Sort(score);
{
for(j=0; j<ROW; 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; i<ROW; i++)
maxPos=minPos=0;
for(n=0; n<10; 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);
printf("Results:\n");
PrintMatrix(c);
return 0;
}
结果:
8-3、
viod DivArray(int pArray[],int n)
{
int i;
for (i=0; i<n; i++)
{
pArray[i]/=pArray[0];
}
}
错误分析:原代码中定义了一个未初始化的指针,而不是数组,有可能会使指针访问到不该访问的内存空间,造成危险,应该定义数组,对数组中的数进行修改操作。
int PositiveNum(int a[],int n)
{
int i,count=0;
for(i=0; i<n; i++)
{
if(a[i]>0)count++;
}
returncount;
}wk.baidu.com
(2)
void Fib(long f[],int n)
{
int i;
f[0]=0;
f[1]=1;
int n;
int m;
n=Readscore(score,num); /*接收人数*/
m=FindMax(score,num,n);
printf("最高的成绩:%d\n学号为:%ld\n",score[m],num[m]);
}
int Readscore(int score[], long num[])
8-6、
#include <stdio.h>
#define N 40
int Readscore(int score[], long num[]);
int FindMax(int score[],long num[],int n);
void main()
{
int score[N];
long num[N];
{
static int a[] = {5,6,7,8},i;
Func(a);
for(i=0; i<4; i++)
{
printf("%d",a[i]);
}
return 0;
}
结果:
分析:数组传递时向函数传递的是数组的地址值,实参与形参共享空间,在被调函数中对数组进行修改就会造成主函数中的数组也被修改。
printf("%d",x);
return 0;
}
结果:
分析:调用函数时只发生值的传递,形参与实参之间再也没有关系,子函数一旦退出,内部变量就释放空间
(2)
#include <stdio.h>
void Func(int b[])
{
int j;
for(j=0; j<4; j++)
{
b[j]=j;
}
}
int main()
一、第八章习题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);
{
for(j=0; j<ROW; j++)
{
c[i][j]=0;
for(k=0; k<COL; 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; i<ROW; i++)
{
int i=-1;
do{
i++;
printf("请输入学号:");
scanf("%ld",&num[i]);
printf("请输入成绩:");
scanf("%d",&score[i]);
}while(score[i]>=0 && num[i]>=0);
return i;
}
int FindMax(int score[],long num[],int n)
{
for(j=0; j<COL; j++)
{
scanf("%d",&a[i][j]);
}
}
printf("Input 3*2 matrix b:\n");
for(i=0; i<COL; i++)
{
for(j=0; j<ROW; j++)
{
scanf("%d",&b[i][j]);
}
}
MultiplyMatrix(a,b,c);
for(i=2; i<n; 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; n<10; n++)
{
scanf("%d",&a[n]);
}
max=min=a[0];
{
int i;
int k;
int max=score[0];
for(i=0; i<n; i++)
{
if(score[i]>max)
{
max=score[i];
k=i;
}
}
return k;
}
结果:
8-7
#include <stdio.h>
void Sort(int score[]);
void Readscore(int score[]);
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; i<ROW; i++)
void main()
{
int score[10];
Readscore(score);
Sort(score);
{
for(j=0; j<ROW; 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; i<ROW; i++)
maxPos=minPos=0;
for(n=0; n<10; 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);
printf("Results:\n");
PrintMatrix(c);
return 0;
}
结果:
8-3、
viod DivArray(int pArray[],int n)
{
int i;
for (i=0; i<n; i++)
{
pArray[i]/=pArray[0];
}
}
错误分析:原代码中定义了一个未初始化的指针,而不是数组,有可能会使指针访问到不该访问的内存空间,造成危险,应该定义数组,对数组中的数进行修改操作。