1、国家二级 C语言机试(操作题)模拟试卷 409及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:找出 100999 之间(含 100和 999)所有整数中各位上数字之和为 x(x为一正整数)的整数,然后输出;符合条件的整数个数作为函数值返回。 例如,当 x值为 5时,100999之间各位上数字之和为 5的整数有:104、113、122、131、140、203、212、221、230、302,311,320、401、410、5000 共有 15个。当 x值为 27时,各位数字之和为 27的整数是:999。只有 1个
2、。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 int fun(int x)3 int n,s1,s2,s3,t ;4 n=0;5 t=100;6 *found*7 while(t= _1_) 8 *found*9 s1=t10;s2=( _2_ )10;s3=t100;10 *found*11 if(s1+s2+s 3=_3_)12 printf(d,t);13 n+;14 15 t+;16 17 return n;18 19 main
3、()20 int x=-1;21 while(x0)22 printf(Please input(x0):); scanf(d,x);23 printf(nThe result is:dn,fun(x);24 (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中函数 fun的功能是:通过某种方式实现两个变量值的交换,规定不允许增加语句和表达式。例如变量 a中的值原为 8,b 中的值原为 3,程序运行后 a中的值为 3,b 中的值为 8。 请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!1 #
4、includestdioh2 int fun(int *x,int y)3 4 int t;5 *found*6 t=x;x=y;7 *found*8 return(y);9 10 main()11 int a=3,b=8;12 printf(ddn,a,b);13 b=fun(a,b);14 printf(ddn,a,b);15 (分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,对长度为 7个字符的字符串,除首、尾字符外,将其余 5个字符按 ASCH码降序排列。例如,原来的字符串为:CEAedca,排序后输出为:CedcEAa。 注意:部分源程序在文件
5、PROG1C 中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。1 #includestdioh2 #includectypeh3 #includestringh4 void fun(char *s,int num)5 67 8 NONO()9 10 *请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。*11 char s10;12 FILE *rf,*wf ;13 int i=0;14 rf=fopen(indat,r);15 wf=fopen(outdat,w);16 while(i10) 17 fgets(s,1
6、0,rf);18 s7=0 ;19 fun(s,7);20 fprintf(wf,sn,s);21 i+;22 23 fclose(rf);24 fclose(wf);25 26 main()27 28 char s10;29 printf(输入 7个字符的字符串:);30 gets(s);31 fun(s,7);32 printf(ns,s);33 NONO();34 (分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 409答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:找出 100999 之间(含
7、100和 999)所有整数中各位上数字之和为 x(x为一正整数)的整数,然后输出;符合条件的整数个数作为函数值返回。 例如,当 x值为 5时,100999之间各位上数字之和为 5的整数有:104、113、122、131、140、203、212、221、230、302,311,320、401、410、5000 共有 15个。当 x值为 27时,各位数字之和为 27的整数是:999。只有 1个。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 i
8、nt fun(int x)3 int n,s1,s2,s3,t ;4 n=0;5 t=100;6 *found*7 while(t= _1_) 8 *found*9 s1=t10;s2=( _2_ )10;s3=t100;10 *found*11 if(s1+s2+s 3=_3_)12 printf(d,t);13 n+;14 15 t+;16 17 return n;18 19 main()20 int x=-1;21 while(x0)22 printf(Please input(x0):); scanf(d,x);23 printf(nThe result is:dn,fun(x);24
9、 (分数:2.00)_正确答案:(正确答案:(1)999 (2)t10 (3)x)解析:解析:在 100999 之间(含 100和 999)所有整数中,取 x的个位、十位和百位,可由x10,x10 再对 10求余、x100 分别得到。第一空:是补充 while循环的终止条件,题干要求 fun寻找 100999 之间满足条件的数 x,因此循环终止条件是 999,故第一空处应填“999”。第二空:“s1=t10;s2=(_2_)10;s3=t100;”可知 s1求得 t的个位数,s3 求得 t的百位数,因此 s2是求 t的十位数。(t10)变量 t变成两位数,再次对 10取余便得到 t的十位数,因
10、此第二空处应为“t10”。第三空:“if(s1+s2+s3=_3_)”是判断 t是否满足题干条件:各位上数字之和为 x,因此第三空处应为“x”。二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中函数 fun的功能是:通过某种方式实现两个变量值的交换,规定不允许增加语句和表达式。例如变量 a中的值原为 8,b 中的值原为 3,程序运行后 a中的值为 3,b 中的值为 8。 请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!1 #includestdioh2 int fun(int *x,int y)3 4 int
11、 t;5 *found*6 t=x;x=y;7 *found*8 return(y);9 10 main()11 int a=3,b=8;12 printf(ddn,a,b);13 b=fun(a,b);14 printf(ddn,a,b);15 (分数:2.00)_正确答案:(正确答案:(1)t=*x;*x=v; (2)return(t);)解析:解析:(1)根据 fun中 x变量的定义,x 为指针型变量,所以第一个错误标识下的“t=x;x=y;”改为“t=-*x;*x=y;”。(2)交换之后 t中存放原来 x的值,x 存放原来 y的值,这里应该是返回原来 x的值,所以第二个标识下的“ret
12、urn(y);”应该改为“return(t);”或者“return t;”。三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,对长度为 7个字符的字符串,除首、尾字符外,将其余 5个字符按 ASCH码降序排列。例如,原来的字符串为:CEAedca,排序后输出为:CedcEAa。 注意:部分源程序在文件 PROG1C 中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。1 #includestdioh2 #includectypeh3 #includestringh4 void fun(char *s,int num)5 67
13、8 NONO()9 10 *请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。*11 char s10;12 FILE *rf,*wf ;13 int i=0;14 rf=fopen(indat,r);15 wf=fopen(outdat,w);16 while(i10) 17 fgets(s,10,rf);18 s7=0 ;19 fun(s,7);20 fprintf(wf,sn,s);21 i+;22 23 fclose(rf);24 fclose(wf);25 26 main()27 28 char s10;29 printf(输入 7个字符的字符串:);30 g
14、ets(s);31 fun(s,7);32 printf(ns,s);33 NONO();34 (分数:2.00)_正确答案:(正确答案:1 char t; 2 int i,j; 3 for(i=1;inum-2;i+) 4 对 n个元素进行循环选择 5 for(j=i+1;jnum-1;j+) 6 if(sisj) 7 将 stri设为最大值,和剩下的jnum-1 进行比较 8 t=si; 9 si=sj; 10 sj=t; 11 )解析:解析:选择排序法中的降序排序,首先从数组中挑选一个最大的元素,把它和第一个元素交换,接着从剩下的 num-1个元素中再挑出一个最大的元素,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。