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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】二级C语言分类模拟题248及答案解析.doc

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

2、N 20 void fun(char(*ss)N) int i, j, n, len=0; for(i=0; iM; i+) len=strlen(ssi); if(i=0)n=len; if(lenn)n=len; for(i=0; iM; i+) /*found*/ n=strlen(_); for(j=0; jlen-n; j+) /*found*/ ssi_=“*“; /*found*/ ssin+j+_=“/0“; main() char ssMN=“shanghai“, “guangzhou“, “beijing“, “tianjing“, “cchongqing“; int i;

3、 printf(“The original strings are:/n“); for(i=0; iM; i+)printf(“%s/n“, ssi); printf(“/n“); fun(ss); printf(“The result is:/n“); for(i=0; iM; i+)printf(“%s/n“, ssi); (分数:30.00)_二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C 中 fun 函数的功能是:将 p 所指字符串中每个单词的最后一个字母改成大写。(这里的“单词”是指由空格隔开的字符串)。 例如,若输入“I am a student to

4、take the examination.”,则应输出“I aM A studenT tO takE thE examination.”。 请修改程序中的错误之处,使它能得出正确的结果。 注意:不要改动 main 函数,不得删行,也不得更改程序的结构! #includectype.h #includestdio.h #includestring.h void fun(char*p) int k=0; for(; *p; p+) if(k) /*found*/ if(p=“ “) k=0; /*found*/ *(p)=toupper(*(p-1) else k=1; main() char c

5、hrstr64; int d; printf(“/nPlease enter an English sentence within 63 letters:“); gets(chrstr); d=strlen(chrstr); chrstrd=“ “; chrstrd+1=0; printf(“/n/nBefore changing:/n %s“, chrstr); fun(chrstr); printf(“/nAfter changing:/n %s“, chrstr); (分数:30.00)_三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,对长度为 7 个字符的字符串,

6、除首、尾字符外,将其余 5 个字符按 ASCII 码降序排列。 例如,原来的字符串为 CEAedca,排序后输出为 CedcEAa。 注意:部分源程序在文件 PROG1.C 中。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入你编写的若干语句。 #includestdio.h #includectype.h #includestring.h void fun(char *s, int num) NONO() /*请在此函数内打开文件,输入测试数据,调用 fun 函数,输出数据,关闭文件。 */ char s10; FILE *rf, *wf; int i=0

7、; rf=fopen(“in.dat“, “r“); wf=fopen(“out.dat“, “w“); while(i10) fgets(s, 10, 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(); (分数:40.00)_二级 C 语言分类模拟题 248 答案解析(总分:100.00,做题时间:90 分钟)一、程序填

8、空题(总题数:1,分数:30.00)1.给定程序中,函数 fun 的功能是:求出形参 ss 所指字符串数组中最长字符串的长度,将其余字符串右边用字符*补齐,使其与最长的字符串等长。ss 所指字符串数组中共有 M 个字符串,且串长N。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在 下的 BLANK1.C 中。 不得增行或删行,也不得更改程序的结构! #includestdio.h #includestring.h #define M 5 #define N 20 void fun(char(*ss)N) int i, j, n, len=0; for

9、(i=0; iM; i+) len=strlen(ssi); if(i=0)n=len; if(lenn)n=len; for(i=0; iM; i+) /*found*/ n=strlen(_); for(j=0; jlen-n; j+) /*found*/ ssi_=“*“; /*found*/ ssin+j+_=“/0“; main() char ssMN=“shanghai“, “guangzhou“, “beijing“, “tianjing“, “cchongqing“; int i; printf(“The original strings are:/n“); for(i=0;

10、iM; i+)printf(“%s/n“, ssi); printf(“/n“); fun(ss); printf(“The result is:/n“); for(i=0; iM; i+)printf(“%s/n“, ssi); (分数:30.00)_正确答案:()解析:(1)ssi (2)n+j (3)1 答案考生文件夹 解析 函数 fun 的功能是求出形参 ss 所指字符串数组中最长字符串的长度。 第一空:第一个循环求最长字符串的长度“len”,在第二个循环内在其他字符串的后面补“*”,使其达到长度“len。”在“for(j=0; jlen-n; j+)”语句中,“jlen-n”是在字符

11、串的后面填“len-n”个“*”,故 n 是字符串“ssi”的长度,因此第一空应为“ssi”。 第二空:循环“for(j=0; jlen-n; j+)”目的是在字符串的后面填 len-n 个“*”,第二空处应为“n+j”。 第三空:字符串以“/0”结束,因此需在字符串后加结束符,故第三空应为“1”。 考点 指向一维数组的指针以及指针数组、for 循环结构。二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C 中 fun 函数的功能是:将 p 所指字符串中每个单词的最后一个字母改成大写。(这里的“单词”是指由空格隔开的字符串)。 例如,若输入“I am a student

12、to take the examination.”,则应输出“I aM A studenT tO takE thE examination.”。 请修改程序中的错误之处,使它能得出正确的结果。 注意:不要改动 main 函数,不得删行,也不得更改程序的结构! #includectype.h #includestdio.h #includestring.h void fun(char*p) int k=0; for(; *p; p+) if(k) /*found*/ if(p=“ “) k=0; /*found*/ *(p)=toupper(*(p-1) else k=1; main() cha

13、r chrstr64; int d; printf(“/nPlease enter an English sentence within 63 letters:“); gets(chrstr); d=strlen(chrstr); chrstrd=“ “; chrstrd+1=0; printf(“/n/nBefore changing:/n %s“, chrstr); fun(chrstr); printf(“/nAfter changing:/n %s“, chrstr); (分数:30.00)_正确答案:()解析:(1)if(*p=“ “) (2)*(p-1)=toupper(*(p-1

14、); 答案考生文件夹 解析 函数的功能是将每个单词的最后一个字母改成大写。 (1)第一个错误标识下的 if 语句应该是判断字符串中的字符是否是空格,根据“for(; *p; p+)”语句中for 循环条件中 p 的定义应该为字符型指针变量,*p 是取 p 所指存取单元的值,所以“if(p=“)”应该改为“if(*p=“)”。 (2)题干中要求是将每个单词的最后一个字母改成大写,所以它的位置应该是挨着空格的前一个字符,应该是指针 p 指向字符的前一个位置,“*p=toupper(*(p-1)”是将改动的值赋给了 p 所指的空格,所以应该改为“*(p-1)=toupper(*(p-1); ”且语句

15、未尾应有分号。 考点 字符数组和字符串、运算符。三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,对长度为 7 个字符的字符串,除首、尾字符外,将其余 5 个字符按 ASCII 码降序排列。 例如,原来的字符串为 CEAedca,排序后输出为 CedcEAa。 注意:部分源程序在文件 PROG1.C 中。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入你编写的若干语句。 #includestdio.h #includectype.h #includestring.h void fun(char *s, int num) NONO() /*

16、请在此函数内打开文件,输入测试数据,调用 fun 函数,输出数据,关闭文件。 */ char s10; FILE *rf, *wf; int i=0; rf=fopen(“in.dat“, “r“); wf=fopen(“out.dat“, “w“); while(i10) fgets(s, 10, 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

17、“, s); NONO(); (分数:40.00)_正确答案:()解析:char t; int i, j; for(i=1; inum-2; i+) /对 n 个元素进行循环选择 for(j=i+1; j-num-1; j+) if(sisj) /将 stri设为最大值,和剩下的 jnum-1 进行比较 t=si; si=sj; sj=t; 答案考生文件夹 解析 选择排序法中的降序排序,首先从数组中挑选一个最大的元素,把它和第一个元素交换,接着从剩下的 num-1 个元素中再挑出一个最大的元素,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。 考点 字符数组和字符串、循环的嵌套。

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