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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、二级 C语言分类模拟题 261及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.给定程序中,函数 fun的功能是建立一个 NN的矩阵。矩阵元素的构成规律是:最外层元素的值全部为 1;从外向内第 2层元素的值全部为 2:第 3层元素的值全部为 3,依次类推。例如,若 N=5,生成的矩阵为: 1 1 1 1 1 1 2 2 2 1 1 2 3 2 1 1 2 2 2 1 1 1 1 1 1 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在 下的 BLANK1.C中。 不得增行或删行,也不得更改程序的结构

2、 #include stdio.h #define N 7 /*found*/ void fun(int(*a)_) int i, j, k, m; if(N%2=0) m=N/2; else m=N/2+1; for(i=0; im; i+) /*found*/ for(j=_; jN-i; j+) aij=aN-i-1j=i+1; for(k=i+1; kN-i; k+) /*found*/ aki=akN-i-1=_; main() int x NN=0, i, j; fun(x); printf(“/nThe result is:/n“); for(i=0; iN; i+) for(

3、j=0; jN; j+) printf(“%3d“, xij); printf(“/n“); (分数:30.00)_二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C中函数 fun的功能是:将十进制正整数 m转换成 k(2k9)进制数,并按高位到低位顺序输出。 例如,若输入 8和 2,则应输出 1000(即十进制数 8转换成二进制表示是 1000)。 请改正 fun函数中的错误,使它能得出正确的结果。 注意:不要改动 main函数。不得增行或删行,也不得更改程序的结构! #includeconio.h #includestdio.h void fun(int m, in

4、t k) int aa20, i; for(i=0; m; i+) /*found*/ aai=m/k; m/=k; for(; i; i-) /*found*/ printf(“%d“, aai); main() int b, n; printf(“/nPlease enter a number and a base:/n“); scanf(“%d %d“, fun(n, b); printf(“/n“); (分数:30.00)_三、程序设计题(总题数:1,分数:40.00)3.编写一个函数,从 num个字符串中找出最长的一个字符串,并通过形参指针 max传回该串地址。(注意:主函数中用*作

5、为结束输入的标志。) 注意:部分源程序在文件 PROG1.C中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 #includestdio.h #includestring.h void fun(char(*a)81, int num, char*max) main() char ss1081, *ps; void NONO(); int n, i=0; printf(“输入若干个字符串:“); gets(ssi); puts(ssi); while(!strcmp(ssi, “*“)=0) i+; gets(ssi); puts(ssi);

6、 n=i; fun(ss, n, printf(“/nmax=%s/n“, ps); NONO(); void NONO() /*请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。 */ char ss2081, *ps; int n, i=0; FILE *rf, *wf; rf=fopen(“in.dat“, “r“); wf=fopen(“out.dat“, “w“); fgets(ssi, 81, rf); while(!strncmp(ssi, “*“, 4)=0) i+; fgets(ssi, 81, rf); n=i; fun(ss, n, fprintf

7、wf, “%s“, ps); fclose(rf); fclose(wf); (分数:40.00)_二级 C语言分类模拟题 261答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.给定程序中,函数 fun的功能是建立一个 NN的矩阵。矩阵元素的构成规律是:最外层元素的值全部为 1;从外向内第 2层元素的值全部为 2:第 3层元素的值全部为 3,依次类推。例如,若 N=5,生成的矩阵为: 1 1 1 1 1 1 2 2 2 1 1 2 3 2 1 1 2 2 2 1 1 1 1 1 1 请在程序的下划线处填入正确的内容并把下划线删除,使程序得

8、出正确的结果。 注意:源程序存放在 下的 BLANK1.C中。 不得增行或删行,也不得更改程序的结构! #include stdio.h #define N 7 /*found*/ void fun(int(*a)_) int i, j, k, m; if(N%2=0) m=N/2; else m=N/2+1; for(i=0; im; i+) /*found*/ for(j=_; jN-i; j+) aij=aN-i-1j=i+1; for(k=i+1; kN-i; k+) /*found*/ aki=akN-i-1=_; main() int x NN=0, i, j; fun(x); p

9、rintf(“/nThe result is:/n“); for(i=0; iN; i+) for(j=0; jN; j+) printf(“%3d“, xij); printf(“/n“); (分数:30.00)_正确答案:()解析:(1)N (2)i (3)i+1 答案考生文件夹 解析 函数 fun的功能是按照指定的规律建立一个 NN的矩阵。 第一空:第一空处是补充函数定义,在主函数内 fun的调用形式是:fun(x),x 是二维数组名,因此 fun函数的参数是一个二维数组指针,故第一空处应为“N ”。 第二空:i 等于 0时,此时第二空下的循环内 a0j=aN-1i=1,显然这是对最外围

10、的两列赋值为1;i 等于 1时,对外向内第 2列元素的值全部赋值为 2,依此类推,故第二空处 j的初值应为“i”。 第三空:“aki=akN-i-1=_; ”是对矩阵的两行进行操作,题干要求矩阵每一圈上的值都相等,故这里和上一个循环的列上的值相同,也为“i+1”。 考点 二维数组、for 循环结构二、程序修改题(总题数:1,分数:30.00)2.给定程序 MODI1.C中函数 fun的功能是:将十进制正整数 m转换成 k(2k9)进制数,并按高位到低位顺序输出。 例如,若输入 8和 2,则应输出 1000(即十进制数 8转换成二进制表示是 1000)。 请改正 fun函数中的错误,使它能得出正

11、确的结果。 注意:不要改动 main函数。不得增行或删行,也不得更改程序的结构! #includeconio.h #includestdio.h void fun(int m, int k) int aa20, i; for(i=0; m; i+) /*found*/ aai=m/k; m/=k; for(; i; i-) /*found*/ printf(“%d“, aai); main() int b, n; printf(“/nPlease enter a number and a base:/n“); scanf(“%d %d“, fun(n, b); printf(“/n“); (分

12、数:30.00)_正确答案:()解析:(1)aai=m%k; (2)printf(“%d“, aai-1); 答案考生文件夹 解析 函数的功能是将十进制正整数 m转换成 k(2k9)进制数。 (1)第二个标识下的“aai=m/k; ”是进制的转换,应该是取余,所以第二个标识下“aaim/k; ”应该改为“aai=m%k; ”。 (2)数制转换处理过程中所得的结果,和实际要输出的结果顺序是相反的,所以必须对存放余数的数组反向输出。原题中“printf(“%d“, aai); ”的下标有误。因为下标 i的起始值为 0,故反向输出时应该从 i-1开始,因此改为“printf(“%d“, aai-1)

13、 ”。 考点 一维数组、顺序程序设计。三、程序设计题(总题数:1,分数:40.00)3.编写一个函数,从 num个字符串中找出最长的一个字符串,并通过形参指针 max传回该串地址。(注意:主函数中用*作为结束输入的标志。) 注意:部分源程序在文件 PROG1.C中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 #includestdio.h #includestring.h void fun(char(*a)81, int num, char*max) main() char ss1081, *ps; void NONO(); int n

14、 i=0; printf(“输入若干个字符串:“); gets(ssi); puts(ssi); while(!strcmp(ssi, “*“)=0) i+; gets(ssi); puts(ssi); n=i; fun(ss, n, printf(“/nmax=%s/n“, ps); NONO(); void NONO() /*请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。 */ char ss2081, *ps; int n, i=0; FILE *rf, *wf; rf=fopen(“in.dat“, “r“); wf=fopen(“out.dat“, “w

15、); fgets(ssi, 81, rf); while(!strncmp(ssi, “*“, 4)=0) i+; fgets(ssi, 81, rf); n=i; fun(ss, n, fprintf(wf, “%s“, ps); fclose(rf); fclose(wf); (分数:40.00)_正确答案:()解析:int i, k=0, maxlen; /*k 为 a数组中最长串所在元素的下标,初始为 0,maxlen 为其串长*/ maxlen=strlen(ak); for(i=1; inum; i+) /*以下完成查找最长串*/ if(strlen(ai)maxlen) maxlen=strlen(ai); k=i; *max=ak; 答案考生文件夹 解析 该程序功能是找出最长的一个字符串。解题思路,首先指定第一个字符串为长度最大的字符串,然后在循环过程中将其与其他的所有串的长度进行比较,求出最长的串。 考点 指向一维数组的指针以及指针数组、for 循环结构。

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