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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

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