- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机C语言国家二级上机
历届C上机模拟参考答案
改错题(共24题)
24..题目:
下面程序是输出以下图形(输出字符之间无空格,每行第一个字符前也没有空格),请改错。
A
BC
CDE
DEFG
EFGHI
#include stdio.h
void main()
{ int i,j;
i=1;
while(i=5) /*$ERROR1$*/
{for(j=i;j2*i;j++)
printf(%c,j+64); /*$ERROR2$*/
printf(\n);
i++; /*$ERROR3$*/
}
}
23..题目:
下面程序完成对于给定的数n,计算F(n)的值(本题假设n小于20),F(n)函数定义如下:F(1)=1,F(2)=1,F(n)=F(n-1)+F(n-2)(当n2时),请改错。
#include stdio.h
#define MAX 20
void main()
{ int n, i;
int f[MAX]; /*$ERROR1$*/
printf(input n:);
scanf(%d,n); /*$ERROR2$*/
f[1]=1;f[2]=1;
for(i=3;i=n;i++) /*$ERROR3$*/
f[i]=f[i-1]+f[i-2];
printf(%d\n,f[n]);
}
22..题目:
以下程序的功能是在mean函数中求数组的平均值,在主函数中输出平均值,输出格式为average:10.00,请改错。
#includestdio.h
float mean(int x[],int num) /*$ERROR1$*/
{int i;
float avg;
for(avg=0,i=0;inum;i++)
avg+=x[i];
avg/=num; /*$ERROR2$*/
return(avg);
}
void main()
{ int i,a[15];
for(i=0;i15;i++)
a[i]=i+3;
printf(average:%6.2f\n,mean(a,15)); /*$ERROR3$*/
}
21..题目:
输入一个字符串c,下面程序是删除字符串c中所有数字字符,请改错。
#include stdio.h
#include string.h /*$ERROR1$*/
void main()
{ int n=0,i;
char c[80];
gets(c); /*$ERROR2$*/
i=0;
while (c[i]!=\0) /*$ERROR3$*/
{ if(c[i]=0c[i]=9) i++;
else { c[n]=c[i];n++;i++;}
}
c[n]=\0;
puts(c);
}
20..题目:
以下程序通过指针操作,输入整型数给数组并对数组进行逆序输出,请改错。
#include stdio.h
void main()
{int a[10],*p;
for(p=a;pa+10;p++)
scanf(%d,p); /*$ERROR1$*/
p=a+9; /*$ERROR2$*/
for(;p=a;p--) /*$ERROR3$*/
printf(%5d,*p);
}
19..题目:
下面程序是从键盘最多输入10个整数,当遇到第一个能被7整除的数时,就打印此数后退出循环;若未遇到,打印“not exist”,请改错。
#include stdio.h
void main()
{ int i,x;
for(i=1;i=10;i++)
{ scanf(%d,x); /*$ERROR1$*/
if(x%7==0) /*$ERROR2$*/
{ printf(%d\n,x);
break; /*$ERROR3$*/
}
}
if(i10) printf(not exist );
}
18..题目:
下面程序是计算1-1/3+1/5-1/7+…的值,直到某项的绝对值小于0.00006为止,请改错。
#include stdio.h
#include math.h
#define EPS 0.00006
void main()
{ long i;
int sing;
double s,t;
i=1;
s=0; /*$ERROR1$*/
sing=1;t=1;
while (fabs(t)=EPS) /*$ERROR2$*/
{s=s+t;
i=i+2; /*$ERROR3$*/
sing=-sing;
t=sing*1.0/i;
}
printf(
文档评论(0)