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

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

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

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

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

    1、国家二级 C语言机试(操作题)模拟试卷 278及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:在 34的矩阵中找出在行上最大、在列上最小的那个元素,若没有符合条件的元素则输出相应信息。 例如,有下列矩阵: 1 2 13 4 7 8 10 6 3 5 9 7 程序执行结果为:find:a22=9 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK1C 中。 不得增行或删行,也不得更改程序的结构! 试题程序: #includestdioh #define N

    2、3 #define N 4 void fun(int(*a)N) int i=0,j,find=0,rmax,c,k; while(iM)&(!find) Emax=ai0; c=0; for(j=1;jN;j+) if(Emaxaij) *found* rmax=aij;c= 【1】 ; find=1;k=0; while(kMfind) *found* if(k!=iakc=Emax) find= 【2】 ; k+; if(find) printf(“find:add=dn“,i,c,aic); *found* 【3】 ; if(!find) printf(“not found!n“);

    3、main() int xMN,i,j; printf(“Enter number for array:n“); for(i=0;iM;i+) for(j=0;jN; j+) scanf(“d“,xij); printf(“The array:n“); for(i=0;iM;i+) for(j=0;jN;j+) printf(“3 d“,xij); printf(“nn“); fun(x); (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.在主函数中从键盘输入若干个数放入数组中,用 0结束输入并放在最后一个元素中。下列给定程序中,函数 fun的功能是:计算数组元素中所有值为正

    4、数的平均值(不包括 0)。例如,数组中元素的值依次为:39、一 47、21、2、一 8、15、0,则程序的运行结果为 19250000。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includeconioh#includestdiohdouble fun(int x)*found* int slim=00; int c=0,i=0; while(xi!=0) if(xi0) sum+=xi; c+; i+; *found* sum=c; return sum;main() int x1000; int i=0; pr

    5、intf(“nPlease enter some clat a(end with 0):“); do scanf(“d“,xi); while(xi+!=0); printf(“lfn“,fun(x);(分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.规定输入的字符串中只包含字母和*号。请编写函数 fun,其功能是:使字符串的前导木号不得多于 n个,若多于 n个,则删除多余的*号;若少于或等于 n个,则不做处理。字符串中间和尾部的*号不删除。例如,字符串中的内容为“*A*BC*DEF*G*”,若 n的值为 4,删除后,字符串中的内容应当是“*A*BC*DEF*G*”;若 n的

    6、值为 8,则字符串中的内容仍为“*A* BC*DEF*G*”。n 的值在主函数中输入。在编写函数时,不得使用 C语言提供的字符串函数。注意:部分源程序给出如下。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#includestdioh#includeconiohvoid fun(char*a,int n)void main() char s81; int n; printf(“Enter a string:n“); gets(s); printf(“Enter n:“); scanf(“d“,n); fun(s,n); printf(

    7、“The string after deleted:n“); puts(s);(分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 278答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:在 34的矩阵中找出在行上最大、在列上最小的那个元素,若没有符合条件的元素则输出相应信息。 例如,有下列矩阵: 1 2 13 4 7 8 10 6 3 5 9 7 程序执行结果为:find:a22=9 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK1C 中。 不得增

    8、行或删行,也不得更改程序的结构! 试题程序: #includestdioh #define N 3 #define N 4 void fun(int(*a)N) int i=0,j,find=0,rmax,c,k; while(iM)&(!find) Emax=ai0; c=0; for(j=1;jN;j+) if(Emaxaij) *found* rmax=aij;c= 【1】 ; find=1;k=0; while(kMfind) *found* if(k!=iakc=Emax) find= 【2】 ; k+; if(find) printf(“find:add=dn“,i,c,aic);

    9、 *found* 【3】 ; if(!find) printf(“not found!n“); main() int xMN,i,j; printf(“Enter number for array:n“); for(i=0;iM;i+) for(j=0;jN; j+) scanf(“d“,xij); printf(“The array:n“); for(i=0;iM;i+) for(j=0;jN;j+) printf(“3 d“,xij); printf(“nn“); fun(x); (分数:2.00)_正确答案:(正确答案:(1)j (2)0 (3)i+)解析:解析:本题是在矩阵中找出在行上

    10、最大、在列上最小的那个元素。 填空 1:找出行上最大的数,并将该数的列数 j保存在 c中,所以应填 j。 填空 2:使用 while循环语句和控制变量 find,如果该数不是列中的最小数,那么把 find置 0,所以应填 0。 填空 3:i 是 while的控制变量,所以每做一次循环,该数值要加 1,所以应填 i+。二、程序修改题(总题数:1,分数:2.00)2.在主函数中从键盘输入若干个数放入数组中,用 0结束输入并放在最后一个元素中。下列给定程序中,函数 fun的功能是:计算数组元素中所有值为正数的平均值(不包括 0)。例如,数组中元素的值依次为:39、一 47、21、2、一 8、15、0

    11、,则程序的运行结果为 19250000。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includeconioh#includestdiohdouble fun(int x)*found* int slim=00; int c=0,i=0; while(xi!=0) if(xi0) sum+=xi; c+; i+; *found* sum=c; return sum;main() int x1000; int i=0; printf(“nPlease enter some clat a(end with 0):“);

    12、do scanf(“d“,xi); while(xi+!=0); printf(“lfn“,fun(x);(分数:2.00)_正确答案:(正确答案:(1)double sum=00; (2)sum=c;)解析:解析:(1)变量定义错误,变量 sum存放所有数据的和,应定义为 double型。 (2)c 语言中的除法运算符是“”。三、程序设计题(总题数:1,分数:2.00)3.规定输入的字符串中只包含字母和*号。请编写函数 fun,其功能是:使字符串的前导木号不得多于 n个,若多于 n个,则删除多余的*号;若少于或等于 n个,则不做处理。字符串中间和尾部的*号不删除。例如,字符串中的内容为“*A

    13、*BC*DEF*G*”,若 n的值为 4,删除后,字符串中的内容应当是“*A*BC*DEF*G*”;若 n的值为 8,则字符串中的内容仍为“*A* BC*DEF*G*”。n 的值在主函数中输入。在编写函数时,不得使用 C语言提供的字符串函数。注意:部分源程序给出如下。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#includestdioh#includeconiohvoid fun(char*a,int n)void main() char s81; int n; printf(“Enter a string:n“); gets(s

    14、); printf(“Enter n:“); scanf(“d“,n); fun(s,n); printf(“The string after deleted:n“); puts(s);(分数:2.00)_正确答案:(正确答案:void fun(char*a,int n) int i=0,k=0; char*p, *t; p=t=a; *开始时,p 与 t同时指向数组的首地址* while(*t=*) *用 k来统计前部星号的个数* k+;t+; if(kn) *如果 k大于 n,则使 p的前部保留 n个星号,其后的字符依次存入数组 a中* while(*p) ai=*(p+kn); i+; p+; ai=0; *在字符串最后加上结束标识* )解析:解析:字符串中前导*号不能多于 n个,多余的应删除。首先需要通过 while循环统计字符串前导*号的个数,然后通过 if条件语句完成前导*号的个数和 n的比较,如果前导*号多于 n个,需要把 n个*号和其余字符重新保留。


    注意事项

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




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

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

    收起
    展开