欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

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

    • 资源ID:1325527       资源大小:40KB        全文页数:7页
    • 资源格式: DOC        下载积分:5000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要5000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    【计算机类职业资格】二级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 循环结构。


    注意事项

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




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

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

    收起
    展开