[计算机类试卷]国家二级C语言机试(操作题)模拟试卷273及答案与解析.doc

上传人:周芸 文档编号:498205 上传时间:2018-11-28 格式:DOC 页数:6 大小:30.50KB
下载 相关 举报
[计算机类试卷]国家二级C语言机试(操作题)模拟试卷273及答案与解析.doc_第1页
第1页 / 共6页
[计算机类试卷]国家二级C语言机试(操作题)模拟试卷273及答案与解析.doc_第2页
第2页 / 共6页
[计算机类试卷]国家二级C语言机试(操作题)模拟试卷273及答案与解析.doc_第3页
第3页 / 共6页
[计算机类试卷]国家二级C语言机试(操作题)模拟试卷273及答案与解析.doc_第4页
第4页 / 共6页
[计算机类试卷]国家二级C语言机试(操作题)模拟试卷273及答案与解析.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

1、国家二级 C语言机试(操作题)模拟试卷 273及答案与解析 一、程序填空题 1 下列给定程序中,函数 fun的功能是:将 s所指字符串中的所有数字字符移到所有非数字字符之后,并保持数字字符串和非数字字符串原有的次序。 例如, s所指的字符串为 “def35adh3kjsdt7”,执行后结果为 “defadhkjsdf3537”。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构 ! 试题程序: #include stdio h void fun(char*s) int i, j=0, k=0; char t

2、180, t280; for(i=0; si!= 0; i+) if(si =0 si =9) t2j=si; 【 1】 ; else t1k+=si; t2j=0; t1k=0; for(i=0; i k; i+) 【 2】 ; for(i=0; i 【 3】 ; i+) sk+i=t2i; main() char s80=“ba3a54j7sd567sdffs“; printf(“ nThe original string is: s n“, S); fun(s); printf(“ nThe result is: s n“, s); 二、程序修改题 2 给定程序 MODI1 C中,函数

3、fun()的功能是统计 s所指一维数组中 0的个数 (存在变量 zero中 )和 1的个数 (存在变量 one中 ),并输出结果。 请改正函数 fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include stdio h void fun(int*s, int n) *found* int i, one=0 , zero; for(i=0; i n; i+) *found* switch(si); *found* case 0: zero+; case 1: one+; printf(“one: d zero

4、: d n“, one, zero); main() int a20=1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0,n=20; fun(a, n); 三、程序设计题 3 请编写函数 fun,其功能是:判断 t所指字符串中的字母是否由连续递增字母序列 组成 (字符串长度大于等于 2)。例如字符串: uvwxyz满足要求;而字符串:uvxwyz不满足要求。 注意:部分源程序存放在 PROG1 C中,请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun指定的部位填入所编写的若干语句。 试题程序: #include s

5、tdio h #include string h void NONO(); int fun(char*t) main() char s26; printf(“请输入一个字母组成的字符串: “); gets(s); if(fun(s)printf(“ s是由连续字母组成的字符串 n“, S); else printf(“ s不是由连续字母组成的字符串 ! n“, S); NONO(); void NONO() *本函数用于打开文件,输人数据,调用函数,输出数据,关闭文件。 * FILE*fp, *wf; int i; char s26, *P; fp=fopen(“C: test in dat“

6、, “r“); wf=fopen (“c: test out dat“, “w“); for(i=0; i 10; i+) fgets(s, 26, fp); p=strchr(s, n); if(p)*p=0; if(fun(s)fprintf(wf, “ s n“, s+2); else fprintf(wf, “ s n“, strrev(s); fclose(fp); fclose(wf); 国家二级 C语言机试(操作题)模拟试卷 273答案与解析 一、程序填空题 1 【正确答案】 (1)j+或 j+=1或 +j或 j=j+1 (2)si=t1i (3)j 【试题解析】 填空 1:根据

7、函数 fun中的内容可知,数组 t1存储了 s中的非数字字符,数组 t2存储了 s中的数字字符,为了存储下一个数字字符,下标 j要进行加 1操作。 填空 2:将 s串中的数字与非数字字符分开后,要先将非数字字符放入字符串 s中,因此填入 si=t1i。 填空 3:再将数字字符加到 s串之后,并且 i要小于数字的个数 j。 二、程序修改题 2 【正确答案】 (1)int i, one=0, zero=0; (2)switch(sj) (3)case 0: zero+; break; 【试题解析】 (1)变量 zero用来统计数字 0的个数,应将其初始化为 0。 (2)语法错误, switch语句

8、后不加分号。 (3)当数字为 0时,变量 zero加 1,此时应使用 break语句跳出 switch语句,进行下一次循环,否则会继续执行 case 1语句,使程序不能得出正确结果。 三、程序设计题 3 【正确答案】 int fun(char*t) int len=strlen(t); if(len 2) return 0; char before ch=t0; char current ch; int flag=1; for (int i=1; ti != 0; +i) current ch=ti; if(before ch!=current ch-1) flag=0; break; bef

9、ore ch=current ch; return flag; 【试题解析】 函数 fun的功能是判断指针 t指向的字符串是否是由连续递增的字母构成,返回值为整数, 0代表不满足条件。根据题目要求,字符串长度必须大于等于 2,所以首先需要对 t指向的字符串进行长度判断,小于 2的字符串返回 0。接着需要对字符串中的连续字符,逐个进行比较。 C语言中字符变量可以当作整数使用,所以当前字符只有是前一个字符的 ASCII码 +1,才能说它们是连续递增字母序列,然后比较后一个字符与当前字符的 ASCII码,如果字符串中的所有字符都满 足条件,则返回 1;否则说明该字符串不满足要求,此时设置 flag=0,后面的字符也就不需要再比较了,跳出循环返回即可。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1