ImageVerifierCode 换一换
格式:DOC , 页数:7 ,大小:35.50KB ,
资源ID:1325657      下载积分:5000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
注意:如需开发票,请勿充值!
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-1325657.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(【计算机类职业资格】二级C语言机试-148及答案解析.doc)为本站会员(eveningprove235)主动上传,麦多课文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文库(发送邮件至master@mydoc123.com或直接QQ联系客服),我们立即给予删除!

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

1、二级 C语言机试-148 及答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)在给定程序中,函数 fun的功能是:求出形参 SS所指字符串数组中最长字符串的长度,其余字符串左边用字符*补齐,使其与最长的字符串等长。字符串数组中共有 M个字符串,且串长N。请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的 BLANK1.C中。不得增行或删行,也不得更改程序的结构。文件 BLANK1.C内容如下:#includestdio.h#includestring.h#define M 5#define N 20

2、void fun(char( *ss)N)int i,j,k=0,n,m,len;for(i=0;iM;i+)len=strlen(ssi);if(i=0)n=len:if(lenn)/*found*/n=len;(1) =i;for(i=0;iM;i+)if(i!=k)m=n:len=strlen(ssi);/*found*/for(j= (2) ;j=0;j-)ssim-=ssij;for(j=0;jn-len;j+)/*found*/(3) =*:void main( )char ssMN=“shanghai“,“guangzhou“,“beijing“,“tianjing“,“ccho

3、ngqing“; int i;printf(“/nThe original strings are: /n“); for(i=0;iM;i+)printf(“%s/n“,ssi);printf(“/n“);fun(ss);printf(“/nThe resuh:/n“);for(i=0;iM;i+)printf(“%s/n“,ssi);(分数:30.00)填空项 1:_填空项 1:_填空项 1:_二、改错题(总题数:1,分数:30.00)1.给定程序 MODI1.C中函数 fun的功能是:求出 s所指字符串中最后一次出现的 t所指字符串的地址,通过函数值返回,在主函数中输出从此地址开始的字符串

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

5、found*/if(r=P)r+;p+;else break;if(*r=/0)a=s;s+:return a;void main( )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:_三、编程题(总题数:1,分数:40

6、00)2.请编写函数 fun,该函数的功能是:判断字符串是否为回文,若是,函数返回 1,主函数中输出 Yes,否则返回 0,主函数中输出 No。回文是指顺读和倒读都一样的字符串。例如:字符串“LEVEL“是回文,而字符串“123312“就不是回文。注意:部分源程序在文件 PROG1.C中。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。文件 PROG1.C内容如下:#includestdio.h#define N 80int fun(char *str)void main( )char sN;printf(“Enter a string:“);

7、gets(s);printf(“/n/n“);puts(s);if(fun(s) printf(“ YES/n“);else printf(“ NO/n“);(分数:40.00)_二级 C语言机试-148 答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)在给定程序中,函数 fun的功能是:求出形参 SS所指字符串数组中最长字符串的长度,其余字符串左边用字符*补齐,使其与最长的字符串等长。字符串数组中共有 M个字符串,且串长N。请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的 BLANK1.C中。

8、不得增行或删行,也不得更改程序的结构。文件 BLANK1.C内容如下:#includestdio.h#includestring.h#define M 5#define N 20void fun(char( *ss)N)int i,j,k=0,n,m,len;for(i=0;iM;i+)len=strlen(ssi);if(i=0)n=len:if(lenn)/*found*/n=len;(1) =i;for(i=0;iM;i+)if(i!=k)m=n:len=strlen(ssi);/*found*/for(j= (2) ;j=0;j-)ssim-=ssij;for(j=0;jn-len;j

9、)/*found*/(3) =*:void main( )char ssMN=“shanghai“,“guangzhou“,“beijing“,“tianjing“,“cchongqing“; int i;printf(“/nThe original strings are: /n“); for(i=0;iM;i+)printf(“%s/n“,ssi);printf(“/n“);fun(ss);printf(“/nThe resuh:/n“);for(i=0;iM;i+)printf(“%s/n“,ssi);(分数:30.00)填空项 1:_ (正确答案:k)解析:填空项 1:_ (正确答案

10、len)解析:填空项 1:_ (正确答案:ssij)解析:解析 main 函数中定义了一个二维的字符数组,其中存放了 5个字符串,调用 fun函数实现题目要求的功能。fun 函数使用的算法是:首先通过第一个 for循环找到最长字符串的行下标并存储在变量 k中。循环中通过 len=strlen(ssi)求出每个字符串的长度,并与变量 n进行比较,若 len比 n大,则对n重新赋值,同时将该字符串的行下标 i记录在变量 k中。循环结束后,变量 n中存放了最长字符串的长度,变量 k中存放了该字符串的行下标。因此,第 1空处应填入变量 k。然后,在第二个循环中,要将其余字符串左边补上*号,使得与最长

11、字符串的长度相等,必须先将每个字符串中的字符右移,循环“for(j=len;j=0;j-)ssim-=ssij;”实现字符右移的功能。所以,第 2空处应填入len,从字符串的结束标记/0开始,依次将字符往右移动。右移结束后,循环“for(j=0;jn-len;j+) ssij=*;”实现每个字符串左补*号,使之与最长的字符串等长。所以第 3空处应填入ssij,即从第一个元素开始,到 n-len结束,对每一个 ssij赋值为*号。二、改错题(总题数:1,分数:30.00)1.给定程序 MODI1.C中函数 fun的功能是:求出 s所指字符串中最后一次出现的 t所指字符串的地址,通过函数值返回,在

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

13、r=t;while(*r)/*found*/if(r=P)r+;p+;else break;if(*r=/0)a=s;s+:return a;void main( )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:_

14、正确答案:第 1处:将“a=Null;”改为“a=NULL;”。第 2处:将“if(r=p)”改为“if(*r=*p)”。)解析:解析 第 1处错误是指针赋值错误,C 语言中的空值用 NULL来表示,“NULL”必须大写。第 2处错误是指针使用错误。题目要求找到最后一次出现 t所指字符串的地址。函数 fun中两个循环嵌套实现找子串的功能,既然是找子串,就必然要将两个字符串中的字符进行比较,而不是将字符串的地址进行比较,所以应该在指针变量的前面加上“*”号,将指针 r和指针 p所指的字符进行是否相等的比较。归纳总结 指针错误是程序修改题中常见的一类错误,也是考生感觉有一定难度的一类题目。指针错

15、误通常出现在 3个方面:(1)指针定义有误。当指针作为形参时,需要通过实参的类型来决定形参指针的类型。尤其要注意实参当一维数组和二维数组时,形参指针的定义格式。(2)指针使用有误。例如,对指针赋值,应该赋予一个地址值;而当要取出指针指向的数据时,需要通过指针运算符“*”来实现。(3)空值书写错误。空值正确的表示是 NULL。三、编程题(总题数:1,分数:40.00)2.请编写函数 fun,该函数的功能是:判断字符串是否为回文,若是,函数返回 1,主函数中输出 Yes,否则返回 0,主函数中输出 No。回文是指顺读和倒读都一样的字符串。例如:字符串“LEVEL“是回文,而字符串“123312“就

16、不是回文。注意:部分源程序在文件 PROG1.C中。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。文件 PROG1.C内容如下:#includestdio.h#define N 80int fun(char *str)void main( )char sN;printf(“Enter a string:“);gets(s);printf(“/n/n“);puts(s);if(fun(s) printf(“ YES/n“);else printf(“ NO/n“);(分数:40.00)_正确答案:(int fun(char *str)int i,

17、j;for(i=0;stri!=/0;i+);j=i-1;for(i=0;ij;i+,j-)if(stri! =strj)return 0;return 1:)解析:解析 函数 fun使用的算法是:首先通过第一个 for循环,求出字符串的长度,第一个 for循环的循环体是一条空语句,跳出循环后变量 i的值即为字符串的长度。执行“j=i-1;”,变量 j记录了字符串最后一个字符的下标。然后通过第二个 for循环进行字符的比较,第一个字符与最后一个字符进行比较,第二个字符和倒数第二个字符进行比较,以此类推,变量 i自加,变量 j自减,如果在比较的过程中,出现 stri!=strj的情况,则通过“return 0;”既中断了循环,又返回了函数值 0。如果在比较的过程中,stri和对应的 strj相等,则不会中断循环,循环正常结束后返回函数值 1。归纳总结 本套试题的程序填空和程序设计题考查的是字符串的比较。字符串的比较可以是长度的比较,也可以是字符串中字符本身的比较。字符串的处理是等级考试试题中的常见题目,在编程处理字符串问题时,要注意数组元素下标的变化规律,尤其是在涉及字符移动的时候。同时,字符串的结束标记/0也是字符串编程时不能忽略的问题。

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