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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】国家二级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个*号和其余字符重新保留。

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