1、国家二级 C语言机试(操作题)模拟试卷 485及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.函数 fun的功能是:将一副扑克牌编号为 1,2,3,53,54,以某种特定的方式洗牌,这种方式是将这副牌分成两半,然后将它们交叉,并始终保持编号为 1的牌在最上方,如第一次这样洗牌后的结果为:1,28,2,29,53,27,54。两次洗牌后的结果为:1,41,28,15,2,42 一一,53,40,27,14,54。 程序的功能是:输出经过 n次这样洗牌后的结果。 请在程序的下画线处填入正确的内容,并把下画线删除,使程序得出正确的结果。 注意:源程序
2、存放在考生文件夹下的 BLANK1C 中。不得增行或删行,也不得更改程序的结构! 试题程序: #include stdioh void fun(int a55, int n) fint i,k; /*found*/ int 【1】 55; for(i=0;i n;i+) for(k=1;k =27;k+) b2*k 一 1=ak; /*found*/ b 【2】 *k=ak+27; for(k=1;k =54;k+) /*found*/ ak= 【3】 ; main() int m a55,i; for(i=1; i 55; i+)ai=i; printf(“请输入洗牌次数:“); scanf
3、(“d“,&m); fun (a, m) ; for (i = 1; i 55; i +) printf (“/n“) ; (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中,函数 fun的功能是:判断输入的任何一个正整数 n,是否等于某个连续正整数序列之和。若是,则输出所有可能的序列,否则输出“不能分解”。例如:当输入 100时,输出:100 =9+10+11+12+13+14+15+16100 =18+19+20+21+22请改正函数 fun中指定部位的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构
4、。试题程序:#include stdioh void fun ( int n ) int j, b, c, m, f1ag=0;for(b=1;b =n/2;b+)/*found*/n=m;c=b;while(m!=0&m =c)/*found*/m=mc;c+/*found*/if(m!=0)printf(“d=“,n);for(j=b;j c 一 1;j+)printf(“d+“,j);printf(“d/n“,j);f1ag=1;if(f1ag=0)printf(“不能分解/n“);main() int n;printi(“请输入一个整数:“);scanf(“d“,&n);fun(n);
5、(分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,其功能是:判断 t所指字符串中的字母是否由连续递增字母序列组成 (字符串长度大于等于 2)。例如字符串:uvwxyz 满足要求;而字符串:uvxwyz 不满足要求。注意:部分源程序存放在PROG1C 中,请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun指定的部位填入所编写的若干语句。试题程序:#1nclucle stclioh #include stringh void NONO();int fun(char*t)main() char s26;printf(“请输入一个字母组成的字符串:“
6、);gets(s);if(fun(s)print:f(“s 是由连续字母组成的字符串*/n“,s);else printf(“s 不是由连续字母组成的字符串!/n“,s);NONO();void NONO()/*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。*/FILE*fp,*wf;int i;char s26,*p;fp;iopen(“c:/test/indat“,“12“);wf=fopen(“c:/test/outdat“,“w“);for(i=0 ; i 10; i+)fgets(s,26,fp);p=strchr(s,/n);if(p)*p=0;if(fun(s)fp
7、rinti(wf,“s/n“,s+2);else fprintf(wf,“s/n“,strrev(s);fclose(fp);fclose(wf);(分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 485答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.函数 fun的功能是:将一副扑克牌编号为 1,2,3,53,54,以某种特定的方式洗牌,这种方式是将这副牌分成两半,然后将它们交叉,并始终保持编号为 1的牌在最上方,如第一次这样洗牌后的结果为:1,28,2,29,53,27,54。两次洗牌后的结果为:1,41,28,15,2,42 一一,
8、53,40,27,14,54。 程序的功能是:输出经过 n次这样洗牌后的结果。 请在程序的下画线处填入正确的内容,并把下画线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。不得增行或删行,也不得更改程序的结构! 试题程序: #include stdioh void fun(int a55, int n) fint i,k; /*found*/ int 【1】 55; for(i=0;i n;i+) for(k=1;k =27;k+) b2*k 一 1=ak; /*found*/ b 【2】 *k=ak+27; for(k=1;k =54;k+) /*foun
9、d*/ ak= 【3】 ; main() int m a55,i; for(i=1; i 55; i+)ai=i; printf(“请输入洗牌次数:“); scanf(“d“,&m); fun (a, m) ; for (i = 1; i 55; i +) printf (“/n“) ; (分数:2.00)_正确答案:(正确答案:(1)b (2)2 (3)bk)解析:解析:填空 1:for 循环中使用了一个数组 b,用来临时存放交换位置后的扑克牌,C 语言中变量需要先声明后使用,所以填空(1)处需要声明一个数组 b。答案为 b。 填空 2:第二个 for循环是将数组 a中前一半元素(即 1一
10、27编号的扑克牌)放入数组 b的奇数位置,将数组 a中的后一半元素(即 2854编号的扑克牌)放入数组 b的偶数位置,实现扑克牌的交叉洗牌。所以填空(2)处是数组 b的起始值为 2的偶数下标 2k,答案为 2。 填空 3:由于数组 b属于函数中的临时变量,所以将数组 a的元素交叉存储到数组 b后,还需要将数组 b的元素依次赋值给数组 a,第三个 for循环实现的功能是将数组 b赋值给数组 a,所以填空(3)处需要填入对应下标为 k的数组 b的元素,答案为 bk。二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中,函数 fun的功能是:判断输入的任何一个正整数 n,是否等
11、于某个连续正整数序列之和。若是,则输出所有可能的序列,否则输出“不能分解”。例如:当输入 100时,输出:100 =9+10+11+12+13+14+15+16100 =18+19+20+21+22请改正函数 fun中指定部位的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构。试题程序:#include stdioh void fun ( int n ) int j, b, c, m, f1ag=0;for(b=1;b =n/2;b+)/*found*/n=m;c=b;while(m!=0&m =c)/*found*/m=mc;c+/*found*
12、/if(m!=0)printf(“d=“,n);for(j=b;j c 一 1;j+)printf(“d+“,j);printf(“d/n“,j);f1ag=1;if(f1ag=0)printf(“不能分解/n“);main() int n;printi(“请输入一个整数:“);scanf(“d“,&n);fun(n);(分数:2.00)_正确答案:(正确答案:(1)m=n; (2)m=m 一 c;c+; (3)if(m=0)解析:解析:(1)每次循环,程序需要对 n执行减去连续的正整数序列来判断 n是否刚好为 0,即 n是否是连续的正整数序列之和,所以需要使用临时变量 m寄存 n的值,每次循
13、环对 m执行减运算操作,不满足继续下一轮。另外,程序声明变量 m时,未初始化它的值,所以此处应该修改为:m=n。 (2)语法错误。C语言中每个语句必须以分号结束,所以应修改为:m=m 一 c;c+;。 (3)题目判断 n是否是连续的正整数序列之和,若是,则输出所有序列,程序中 m依次减去连续的正整数,当 m为 0时,表示 m(即 n)满足条件,再输出当前序列中的每个正整数,所以此处判断条件反了,应修改为:if(m=0)。三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,其功能是:判断 t所指字符串中的字母是否由连续递增字母序列组成 (字符串长度大于等于 2)。例如字符串:uv
14、wxyz 满足要求;而字符串:uvxwyz 不满足要求。注意:部分源程序存放在PROG1C 中,请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun指定的部位填入所编写的若干语句。试题程序:#1nclucle stclioh #include stringh void NONO();int fun(char*t)main() char s26;printf(“请输入一个字母组成的字符串:“);gets(s);if(fun(s)print:f(“s 是由连续字母组成的字符串*/n“,s);else printf(“s 不是由连续字母组成的字符串!/n“,s);NONO();void
15、NONO()/*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。*/FILE*fp,*wf;int i;char s26,*p;fp;iopen(“c:/test/indat“,“12“);wf=fopen(“c:/test/outdat“,“w“);for(i=0 ; i 10; i+)fgets(s,26,fp);p=strchr(s,/n);if(p)*p=0;if(fun(s)fprinti(wf,“s/n“,s+2);else fprintf(wf,“s/n“,strrev(s);fclose(fp);fclose(wf);(分数:2.00)_正确答案:(正确答案:int
16、 fun(char*t) int fen=str1en(t); if(1en 2) return 0; char before_ch=t0; char current_ch; int f1ag=1 ; for(int i=1;ti!=/ 0;+i) current_ch=ti; if fbefore_ch!=cur rent_ch 一 1) f1ag=0 ; break; before_ch=current_ch; return f1ag; )解析:解析:函数 fun的功能是判断指针 t指向的字符串是否是由连续递增的字母构成,返回值为整数,0代表不满足条件。根据题目要求,字符串长度必须大于等于 2,所以首先需要对 t指向的字符串进行长度判断,小于 2的字符串返回 0。接着需要对字符串中的连续字符,逐个进行比较。C 语言中字符变量可以当作整数使用,所以当前字符只有是前一个字符的 ASCII码+1,才能说它们是连续递增字母序列,然后比较后一个字符与当前字符的 ASCII码,如果字符串中的所有字符都满足条件,则返回 1;否则说明该字符串不满足要求,此时设置 flag=0,后面的字符也就不需要再比较了,跳出循环返回即可。