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

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

1、二级 C语言机试-252 及答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)请补充函数 proc(),函数 proc()的功能是求 7的阶乘。注意:部分源程序已给出。请勿改动主函数 main和其他函数中的任何内容。试题程序:#includestdio.hlong proc(int n)if( (1) )return(n * proc( (2) );else if( (3) )return 1;void main()int k=7;printf(“%d!=%ld/n“, k, proc(k);(分数:30.00)填空项 1:_填空项 1:_填空项 1

2、二、改错题(总题数:1,分数:30.00)1.下列给定的程序中,函数 proc()的功能是:用选择法对数组中的 m个元素按从小到大的顺序进行排序。例如,排序前的数据为:11 32 -5 2 14则排序后的数据为:-5 2 11 14 32请修改程序中的错误,使它能得到正确结果。注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。试题程序:#includestdio.h#define M 20void proe(int a, int n)int i, j, t, p;/*found*for(j=0; jn=1; j+);p=j;for(i=j; in; i+)if(aia

3、p)p=i;t=ap;ap=aj;/*found*ap=t;void main()int arrM=11, 32, -5, 2, 14, i, m=5;printf(“排序前的数据: “);for(i=0; im; i+)printf(“%d“, arri);printf(“/n“);proc(art, m);printf(“排序后的顺序: “);for(i=0; im; i+)printf(“%d“, arri);printf(“/n“);(分数:30.00)填空项 1:_三、编程题(总题数:1,分数:40.00)2.请编写函数 proc(),该函数的功能是:将放在字符串数组中的 M个字符串

4、每串的长度不超过 N),按顺序合并组成一个新的字符串。例如,若字符串数组中的 M个字符串为:ABCDBCDEFGCDEFGHI则合并后的字符串内容应该是 ABCDBCDEFGCDEFGHI注意:部分源程序已给出。请勿改动主函数 main和其他函数中的任何内容。试题程序:#includestdio.h#includeconio.h#define M 3#define N 20void proc(char arrMN, char*b)void main()char strMN=(“ABCD“, “BCDEFG“, “CDEFGHI“), i;char arr100=“#“);printf(“Th

5、e string: /n“);for(i=0; iM; i+)puts(stri);printf(“/n“);proc(str, arr);printf(“The A string: /n“);printf(“%s“, arr);printf(“/n/n“);(分数:40.00)_二级 C语言机试-252 答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)请补充函数 proc(),函数 proc()的功能是求 7的阶乘。注意:部分源程序已给出。请勿改动主函数 main和其他函数中的任何内容。试题程序:#includestdio.hlong proc(

6、int n)if( (1) )return(n * proc( (2) );else if( (3) )return 1;void main()int k=7;printf(“%d!=%ld/n“, k, proc(k);(分数:30.00)填空项 1:_ (正确答案:n1)解析:填空项 1:_ (正确答案:n-1)解析:填空项 1:_ (正确答案:n=1)解析:解析 本题求阶乘是由函数递归调用来实现的。N!=N*(N-1)!,直到 N=1。因此1处填 n1;由递归的性质可知2处填 n-1;直到 N=1时结束递归调用,因此3处填 n=1。二、改错题(总题数:1,分数:30.00)1.下列给定的

7、程序中,函数 proc()的功能是:用选择法对数组中的 m个元素按从小到大的顺序进行排序。例如,排序前的数据为:11 32 -5 2 14则排序后的数据为:-5 2 11 14 32请修改程序中的错误,使它能得到正确结果。注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。试题程序:#includestdio.h#define M 20void proe(int a, int n)int i, j, t, p;/*found*for(j=0; jn=1; j+);p=j;for(i=j; in; i+)if(aiap)p=i;t=ap;ap=aj;/*found*ap=t;

8、void main()int arrM=11, 32, -5, 2, 14, i, m=5;printf(“排序前的数据: “);for(i=0; im; i+)printf(“%d“, arri);printf(“/n“);proc(art, m);printf(“排序后的顺序: “);for(i=0; im; i+)printf(“%d“, arri);printf(“/n“);(分数:30.00)填空项 1:_ (正确答案:(1)错误:for(j=0; jn=1; j+); 正确:for(j=0; jn=1; j+)(2)错误:ap=t; 正确:aj=t;)解析:解析 for 循环结束的

9、标志是 for后的一个语句,如果 for后面直接跟一个分号,说明是一个空循环,不执行任何功能,因此“for(j=0; jn=1; j+);”后面的分号应该去掉;当 aiap时两元素互换,因此“ap=t;”应改为“aj=t;”。三、编程题(总题数:1,分数:40.00)2.请编写函数 proc(),该函数的功能是:将放在字符串数组中的 M个字符串(每串的长度不超过 N),按顺序合并组成一个新的字符串。例如,若字符串数组中的 M个字符串为:ABCDBCDEFGCDEFGHI则合并后的字符串内容应该是 ABCDBCDEFGCDEFGHI注意:部分源程序已给出。请勿改动主函数 main和其他函数中的任

10、何内容。试题程序:#includestdio.h#includeconio.h#define M 3#define N 20void proc(char arrMN, char*b)void main()char strMN=(“ABCD“, “BCDEFG“, “CDEFGHI“), i;char arr100=“#“);printf(“The string: /n“);for(i=0; iM; i+)puts(stri);printf(“/n“);proc(str, arr);printf(“The A string: /n“);printf(“%s“, arr);printf(“/n/n

11、);(分数:40.00)_正确答案:(void proc(char arrMN, char*b)int i, j, k=0;for(i=0; iM; i+) /i 表示其行下标for(j=0; arrij!=/0; j+) /因此每行的个数不等,因此用 aij!=/0来作为循环结束的条件bk+=arrij; /把二维数组中的元素放到 b的一维数组中,bk=/0; /最后把 b赋/0作为字符串结束的标志)解析:解析 字符串数组中每一行都是一个一个完整的字符串,其结束标志为/0。因此通过字符串的结束标志来判断每一个字符串是否结束,将字符串数组中的所有字符串均赋值新的一维数组 b来完成字符串的合并。

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

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

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