1、国家二级 C语言机试(操作题)模拟试卷 36及答案与解析 一、程序填空题 1 函数 fun的功能是:统计长整数 n的各个位上出现数字 1、 2、 3的次数,并通过外部 (全局 )变量 c1, c2, c3返回主函数。例如:当 n=123114350时,结果应该为:C1=3 c2=1c3=2。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANKl C中。 不得增行或删行,也不得更改程序的结构 ! #include int c1, c2, c3 ; void fun(long n) c1=c2=c3=0 ; while(n) /*f
2、ound*/ switch( _1_ ) /*found*/ case 1: c1+; _2_ ; /*found*/ case 2: c2+; _3_ ; case 3: c3+; n =10; main() long n=123114350L; fun(n); printf(“ nThe result : n”); printf(“n= ld c1= d c2= d c3= d n”, n, c1, c2, c3); 二、程序修改题 2 给定程序 MODII C中函数 fun的功能是:将字符串中的字符按逆序输出,但不改变字符串中的内容。 例如,若字符串为 abed,则应输出: dcba。
3、请改正程序中的错误,使它能计算出正确的结果 。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构 ! #include /*found*/ fun(char a) if (*a) fun(a+1); /*found*/ printf(“ c”*a); main() char s1 0=“abcd”; printf(“处理前字符串 = s n处理后字 符串 =”, s); fun(s); printf(“ n”); 三、程序设计题 3 请编写函数 fun,对长度为 7个字符的字符串,除首、尾字符外,将其余 5个字符按 ASCII码降序排列。 例如,原来的字符串为 CEAedca
4、,排序后输出为 CedcEAa。 注意:部分源程序在文件 PROGl C中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 #include #include #include void fun(char *s, int num) NONO() *请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。 * char s10; FILE *rf, *wf; int i=0; rf= fopen(“in dat”, “r”); wf=fopen(“out dat”, “w”); while(i10) fgets(s, 10,
5、rf); s7=0; fun(s, 7); fprintf(wf, “ s n”, s); i+ ; fclose(rf); fclose(wf); main() char s10; printf(“输入 7个字符的字符串 :”); gets(s); fun(s, 7); printf(“ n s”, s); NONO(); 国家二级 C语言机试(操作题)模拟试卷 36答案与解析 一、程序填空题 1 【正确答案】 (1)n 10 (2)break (3)break 【试题解析】 函数 fun的功能是统计长整数 n的各个位上出现数字 1、 2、 3的次数,分别判断 n的各位数是否是 1、 2、
6、3,如果是再在各自的计数变量上加 1。 解题思路 第一空: switch内部是统计数字 1、 2、 3的个数,因此 switch条件是 n的一位数。由 “n =10: ”在循环中, n每次减小为以前的 1 10,即 n逐步往打边移出一个整数位,移出的整数位可由 n 10可求得,故第一空处应填 “n 10”。 第二空: C语言中, case语句后都要加 “break”语句,否则会执行多个 case语句,因此第二空处应为 “break”。 第三空:理由同上,第三空处应填 “break”。 二、程序修改题 2 【正确答案】 (1)void fun(char *a) (2)printf(“ c”, *
7、a); 【试题解析】 本题中函数的功能是将字符串中的内容逆序。题干中给出的 fun函数通过递归调用自身,实现字符串的逆序。 解题思路 (1)主函数中 “fun(s): ”语句中的 s是数组名,所以在 fun函数中参数的定义应该是指针型, “fun(char a)”改为 “void fun(char *a)”。 (2)printf函数的州用形式是: printf(格式字符串,输出项表 ),在格式字符串和输出项表之间有 “, ”,因此第二个标识处应该是 “printf(“ c“, *a); ”。 三、程序设计题 3 【正确答案】 Char t; int i, j; for(i=1 ; inum一 2; i+) 对 n个元素进行循环选择 for(j=i+1; jnum一 1 ; j+) if(sisj) 将 stri设为最大值,和剩下的 j-num一 1进行比较 t=si; si=sj; sj=t; 【试题解析】 选择排序法中的降序排序,首先从数组中挑选一个最大的元素,把它和第一个元素交换,接着从剩下的 num1个元素中再挑出一个最大的元素,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1