- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
2014年计算机二级C语言上机模拟试题及答案12014年计算机二级C语言上机模拟试题及答案1
2014年上半年计算机二级C语言上机模拟试题及答案1
填空题
函数FUN的功能是:逆置数组元素中的值。形参N给出数组中的数据的个数。
例如:若A所指数组中的数据依次为:1、2、3、4、5、6、7、8、9,则逆置后依次为:9、8、7、6、5、4、3、2、1。
注意:部分源程序给出如下
请勿改动主函数main和其他函数中的任何内容,仅在横线上填入所编写的若干表达式或语句。
试题程序:#include
void fun(int a[], int n)
{
int i, t;
for (i=0; i___1___; i++)
{
t = a[i];
a[i] = a[n-1-___2___];
___3___ = t;
}
}
main()
{
int b[9] = {1, 2, 3, 4, 5, 6, 7, 8, 9}, i;
printf(\nThe original data :\n);
for (i=0; i9; i++)
printf(%4d , b[i]);
printf(\n);
fun(b, 9);
printf(\nThe data after invert :\n);
for (i=0; i9; i++)
printf(%4d , b[i]);
printf(\n);
}
第1处填空:n/2
第2处填空:i
第3处填空:a[n-i-1]
改错题
下列给定程序中,函数fun的功能是:从s所指字符串中,找出t所指子串的个数作为函数值返回,例如,当s所指字符串中的内容为abcdabfab,t 所指字符串的内容为ab,则函数返回整数3。
请改正程序中的 错误,使它能得也正确的结果,
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题 程序:
#include
#include
#include
int fun(char *s, char *t)
{
int n;
char *p, *r;
n = 0;
while (*s)
{
p = s;
r = t;
while (*r)
/********found********/
if (r == p)
{
r++;
p++;
}
else
{
break;
}
/********found********/
if (r == \0)
n++;
s++;
}
return n;
}
main()
{
char s[100], t[100];
int m;
printf(\nPlease enter string s:);
scanf(%s, s);
printf(\nPlease enter substring t:);
scanf(%s, t);
m = fun(s, t);
printf(\nThe result is: m=%d\n, m);
}
第1处:if (r==p)应改为if(*r==*p)
第2处:if(r==’\0’)应改为if(*r==’\0’)
编程题
编写???数fun,它的功能是:将一个数字字符串转换为一个整数(不得调用C语言中提供的将字符串转换成整 数的函数。)
例如 若输入字符串“-1234“,则 函数把它转换为整数值-1234。
注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
试题程序:#include
#include
long fun ( char *p)
{
}
main()
{
char s[6];
long n;
FILE *out;
char *test[] = {-1234, 5689, 7102, -4356};
printf(Enter a string:\n);
gets(s);
n = fun(s);
printf(%ld\n,n);
out=fopen(out.dat, w);
for(n=0;n4;n++)
fprintf(out, %ld\n, fun(test[n]));
fclose(out);
}
答案是:
long fun(char *p)
{
long s=0,t;
int i=0,j,n=strlen(p),k,s1;
if(p[0]==’-’)
i++;
文档评论(0)