【计算机类职业资格】二级C语言-575及答案解析.doc

上传人:bonesoil321 文档编号:1325406 上传时间:2019-10-17 格式:DOC 页数:7 大小:34KB
下载 相关 举报
【计算机类职业资格】二级C语言-575及答案解析.doc_第1页
第1页 / 共7页
【计算机类职业资格】二级C语言-575及答案解析.doc_第2页
第2页 / 共7页
【计算机类职业资格】二级C语言-575及答案解析.doc_第3页
第3页 / 共7页
【计算机类职业资格】二级C语言-575及答案解析.doc_第4页
第4页 / 共7页
【计算机类职业资格】二级C语言-575及答案解析.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

1、二级 C 语言-575 及答案解析(总分:30.00,做题时间:90 分钟)一、填空题(总题数:1,分数:1.00)1.请补充函数 fun(),该函数的功能是:分类统计一个字符串中元音字母和其他字符的个数(不区分大小写)。 例如,输入 aeiouAOUpqrt,结果为 A2 E1 I1 O2 U2 Other4。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun()的横线上填入所编写的若干表达式或语句。 试题程序: #includestdioh #includeconioh #define N 100 void fun(char *str,int

2、bb ) char *p=str; int i=0; for(i=0;i6;i+) _ 1_ ; while(*p) switch(*p) case “A“: case “a“:bb0+;break; case “E“: case “e“:bb1+;break; case “I“: case “i“:bb2+;break; case “O“: case “o“:bb3+;break; case “U“: case “u“:bb4+;break; default: _ 2_ ; _ 3_ main() char strN,ss6=“AEIOU“; int i; int bb6; clrscr()

3、; printf(“Input a string:/n“); gets(str); printf(“the string is:/n“); puts(str); fun(str,bb); for(i=0;i5;i+) printf(“/n%c:%d“,ssi,bbi); printf(“/nother:%d“,bbi); (分数:1.00)二、改错题(总题数:1,分数:30.00)2.给定程序 MODI1.C 中函数 fun 的功能是:求出 s 所指字符串中最后一次出现的 t 所指字符串的地址,通过函数值返回,在主函数中输出从此地址开始的字符串。若未找到,则函数的返回值为 NULL。例如,字符

4、串 s 中的内容为“abcdabfabcdx”,若 t 中的内容为“ah”时,则输出结果为:abcdx;若 t 中的内容为“abd”,则程序输出未找到的信息:not be found!。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 文件 MODI1.C 内容如下: #includestdio.h #includestring.h char *fun(char *s,char *t) char *p,*r,*a; /*found*/ a=NUll; while(*s) p=s;r=t; while(*r) /*found*/

5、 if(r=P)r+;p+; else break; if(*r=“/0“)a=s; s+: return a; void main 1 char s100,t100,*p; printf(“/nPlease enter string s: “); scanf(“%s“,s); printf(“/nPlease enter string t: “); scanf(“%s“,t); p=fun(s,t); if(P)printf(“/nTbe result is: %s/n“,p); else printf(“/nNot found!/n“); (分数:30.00)三、编程题(总题数:1,分数:

6、-1.00)3.请编写函数 fun(),对长度为 7 个字符的字符串,除首、尾字符外,将其余 5 个字符按 ASCII 码值升序排列。 例如:原来的字符串为 BdsihAd,则排序后输出为 BAdhisd。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。 试题程序: #include stdio.h #include ctype.h #include conio.h int fun(char*s,int num) main() char s10; clrscr(); printf(“输入 7 个字符的字符串:“)

7、; gets(s); fun(s,7); printf(“/n%s“,s); (分数:-1.00)_二级 C 语言-575 答案解析(总分:30.00,做题时间:90 分钟)一、填空题(总题数:1,分数:1.00)1.请补充函数 fun(),该函数的功能是:分类统计一个字符串中元音字母和其他字符的个数(不区分大小写)。 例如,输入 aeiouAOUpqrt,结果为 A2 E1 I1 O2 U2 Other4。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun()的横线上填入所编写的若干表达式或语句。 试题程序: #includestdioh #in

8、cludeconioh #define N 100 void fun(char *str,int bb ) char *p=str; int i=0; for(i=0;i6;i+) _ 1_ ; while(*p) switch(*p) case “A“: case “a“:bb0+;break; case “E“: case “e“:bb1+;break; case “I“: case “i“:bb2+;break; case “O“: case “o“:bb3+;break; case “U“: case “u“:bb4+;break; default: _ 2_ ; _ 3_ main(

9、) char strN,ss6=“AEIOU“; int i; int bb6; clrscr(); printf(“Input a string:/n“); gets(str); printf(“the string is:/n“); puts(str); fun(str,bb); for(i=0;i5;i+) printf(“/n%c:%d“,ssi,bbi); printf(“/nother:%d“,bbi); (分数:1.00)解析:1 bbi=0 2 bb5+ 3 p+;解析 填空 1:数组 bb6用来存放 5 个元音字母和其他字符的个数,在使用之前需要清零。填空 2:数组元素 bb

10、5用来存放其他字符的个数,当指针 p 所指的字符不是元音字母时,则认为是其他字符,bb5加 1。填空 3:指针 p 指向字符串 str,通过 p 自加 1 来移动指针,访问字符串中的所有字符。二、改错题(总题数:1,分数:30.00)2.给定程序 MODI1.C 中函数 fun 的功能是:求出 s 所指字符串中最后一次出现的 t 所指字符串的地址,通过函数值返回,在主函数中输出从此地址开始的字符串。若未找到,则函数的返回值为 NULL。例如,字符串 s 中的内容为“abcdabfabcdx”,若 t 中的内容为“ah”时,则输出结果为:abcdx;若 t 中的内容为“abd”,则程序输出未找到

11、的信息:not be found!。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 文件 MODI1.C 内容如下: #includestdio.h #includestring.h char *fun(char *s,char *t) char *p,*r,*a; /*found*/ a=NUll; while(*s) p=s;r=t; while(*r) /*found*/ if(r=P)r+;p+; else break; if(*r=“/0“)a=s; s+: return a; void main 1 char s

12、100,t100,*p; printf(“/nPlease enter string s: “); scanf(“%s“,s); printf(“/nPlease enter string t: “); scanf(“%s“,t); p=fun(s,t); if(P)printf(“/nTbe result is: %s/n“,p); else printf(“/nNot found!/n“); (分数:30.00)解析:第 1 处:将“a=Null;”改为“a=NULL;”。 第 2 处:将“if(r=p)”改为“if(*r=*p)”。 解析 第 1 处错误是指针赋值错误,C 语言中的空值用

13、NULL 来表示,“NULL”必须大写。第 2 处错误是指针使用错误。题目要求找到最后一次出现 t 所指字符串的地址。函数 fun 中两个循环嵌套实现找子串的功能,既然是找子串,就必然要将两个字符串中的字符进行比较,而不是将字符串的地址进行比较,所以应该在指针变量的前面加上“*”号,将指针 r 和指针p 所指的字符进行是否相等的比较。 归纳总结 指针错误是程序修改题中常见的一类错误,也是考生感觉有一定难度的一类题目。指针错误通常出现在 3 个方面: (1)指针定义有误。当指针作为形参时,需要通过实参的类型来决定形参指针的类型。尤其要注意实参当一维数组和二维数组时,形参指针的定义格式。 (2)指

14、针使用有误。例如,对指针赋值,应该赋予一个地址值;而当要取出指针指向的数据时,需要通过指针运算符“*”来实现。 (3)空值书写错误。空值正确的表示是 NULL。三、编程题(总题数:1,分数:-1.00)3.请编写函数 fun(),对长度为 7 个字符的字符串,除首、尾字符外,将其余 5 个字符按 ASCII 码值升序排列。 例如:原来的字符串为 BdsihAd,则排序后输出为 BAdhisd。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。 试题程序: #include stdio.h #include ctyp

15、e.h #include conio.h int fun(char*s,int num) main() char s10; clrscr(); printf(“输入 7 个字符的字符串:“); gets(s); fun(s,7); printf(“/n%s“,s); (分数:-1.00)_正确答案:()解析:int fun(char*s,int num) char t; int i,j; for(i=1;inum-2;i+) /*下标值从 1 开始,用循环依次取得字符串中的字符*/ for(j=i+1;jnum-1;j+) /*将字符与其后的每个字符比较*/ if(sisj) /*如果后面字符的 ASCII 码值小于该字符的 ASCII 码值*/ t=si; /*则交换这两个字符* si=sj; sj=t; 解析 本题考查利用循环来控制数组元素的操作,首尾元素除外,因此,数组的下标值要从 1 开始,用循环变量 i 来依次取得数组中的元素,用数组中的元素 si和 sj进行比较,如果后一个元素的ASCII 码值小于前一个元素的 ASCII 码值,则交换这两个数组元素的值。

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

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

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