- 1、本文档共17页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
c语言第八章课后题答案
一、第八章习题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];
}
}
错误分析:原代
文档评论(0)