【计算机类职业资格】国家二级C语言机试(操作题)模拟试卷522及答案解析.doc

上传人:diecharacter305 文档编号:1332332 上传时间:2019-10-17 格式:DOC 页数:3 大小:31.50KB
下载 相关 举报
【计算机类职业资格】国家二级C语言机试(操作题)模拟试卷522及答案解析.doc_第1页
第1页 / 共3页
【计算机类职业资格】国家二级C语言机试(操作题)模拟试卷522及答案解析.doc_第2页
第2页 / 共3页
【计算机类职业资格】国家二级C语言机试(操作题)模拟试卷522及答案解析.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

1、国家二级 C语言机试(操作题)模拟试卷 522及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:求出形参 ss所指字符串数组中最长字符串的长度,将其余字符串右边用字符“*”补齐,使其与最长的字符串等长。ss 所指字符串数组中共有 M个字符串,且串长 #include #define M 5 #define N 20 void fun (char (*ss)N) int i, j, n, len=0; for(i=0; in)n=len; for(i=0; i_二、程序修改题(总题数:1,分数:2.00)2.给定程

2、序 MODI1C 中 fun函数的功能是:将 p所指字符串中每个单词的最后一个字母改成大写。(这里的“单词”是指由空格隔开的字符串)。 例如,若输入“I am a student to take the examination”,则应输出“I aM A studenT tO take thE examination”。 请修改程序中的错误之处,使它能得出正确的结果。 注意:不要改动 main函数,不得删行,也不得更改程序的结构! #include #include #include void fun(char *p) int k = 0; for(; *p; p+) if (k) /* fou

3、nd*/ if(p = ) k = 0; /* found*/ * (p) = toupper(*(p - 1) else k = 1; main () char 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(“/nAfte

4、r changing:/n %s“, chrstr); (分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,对长度为 7个字符的字符串,除首、尾字符外,将其余 5个字符按 ASCH码降序排列。例如,原来的字符串为:CEAedca,排序后输出为:CedcEAa。 注意:部分源程序在文件 PROG1C 中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 #include #include #include void fun(char *s,int num) NONO() /*请在此函数内打开文件,输入测试数据,

5、 调用 fun函数,输出数据,关闭文件。*/ char s10 ; FILE *rf, *wf ; int i = 0 ; rf = fopen(“in.dat“,“r“) ; wf = fopen(“out.dat“,“w“); while(i 10) fgets(s,10,rf); s7 =0 ; fun(s,7) ; fprintf(wf, “%s/n“, s); i+ ; fclose(rf); fclose(wf); main () char s 10; printf (“输入 7个字符的字符串: “) ; gets (s); fun(s,7); printf(“/n%s“,s);

6、NONO(); (分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 522答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:求出形参 ss所指字符串数组中最长字符串的长度,将其余字符串右边用字符“*”补齐,使其与最长的字符串等长。ss 所指字符串数组中共有 M个字符串,且串长 #include #define M 5 #define N 20 void fun (char (*ss)N) int i, j, n, len=0; for(i=0; in)n=len; for(i=0; i_正确答案:(正确答案

7、:(1)ssi (2)n+j (3)1)解析:解析:函数 fun的功能是求出形参 ss所指字符串数组中最长字符串的长度。 第一空:第一个循环求最长字符串的长度“len”,在第二个循环内在其他字符串的后面补“*”,使其达到长度“len。”在“for(j:0;jlen-n;j+)”语句中,“j二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中 fun函数的功能是:将 p所指字符串中每个单词的最后一个字母改成大写。(这里的“单词”是指由空格隔开的字符串)。 例如,若输入“I am a student to take the examination”,则应输出“I aM A s

8、tudenT tO take thE examination”。 请修改程序中的错误之处,使它能得出正确的结果。 注意:不要改动 main函数,不得删行,也不得更改程序的结构! #include #include #include 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 chrstr64; int d ; printf(“/nPlease enter an En

9、glish 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); (分数:2.00)_正确答案:(正确答案:(1)if(*p=) (2)*(p 一 1)=toupper(*(p一 1);)解析:解析:函数的功能是将每个单词的最后一个字母改成大写。 (1)第一个错误标

10、识下的 if语句应该是判断字符串中的字符是否是空格,根据“for(;*p;p+)”语句中 for循环条件中 p的定义应该为字符型指针变量,*p 是取 p所指存取单元的值,所以“if(p=)”应该改为“if(*p=)”。 (2)题干中要求是将每个单词的最后一个字母改成大写,所以它的位置应该是挨着空格的前一个字符,应该是指针 p指向字符的前一个位置,“*p=toupper(*(p 一 1)”是将改动的值赋给了 p所指的空格,所以应该改为“*(p-1)=toupper(*(p-1);”且语句未尾应有分号。三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,对长度为 7个字符的字符串,

11、除首、尾字符外,将其余 5个字符按 ASCH码降序排列。例如,原来的字符串为:CEAedca,排序后输出为:CedcEAa。 注意:部分源程序在文件 PROG1C 中。 请勿改动主函数 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“)

12、 ; wf = fopen(“out.dat“,“w“); while(i 10) fgets(s,10,rf); s7 =0 ; fun(s,7) ; fprintf(wf, “%s/n“, s); i+ ; fclose(rf); fclose(wf); main () char s 10; printf (“输入 7个字符的字符串: “) ; gets (s); fun(s,7); printf(“/n%s“,s); NONO(); (分数:2.00)_正确答案:(正确答案: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; )解析:解析:选择排序法中的降序排序,首先从数组中挑选一个最大的元素的 ascill码,把它和第一个元素交换,接着从剩下的 num-1个元素中再挑出一个最大的元素的 ascill码,把它和第二个元素交换,不断重复以上过程,直到比较完最后两个元素。

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

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

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