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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C语言机试(操作题)模拟试卷 269及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.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 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK1C 中。 不得增行或删行,也不得更改程

2、序的结构! 试题程序: 1 #includestdioh 2 #defitie N 7 3 *found* 4 void fun(int(*a) 【1】 ) 5 int i,j,k,m; 6 if(N2=0)m=N2; 7 else m=N2+1; 8 for(i=0;im;i+) 9 *found* 10 for(j= 【2】 ;jN i;j+) 11 aij=aNi 一 1j=i+1; 12 for(k=i+1;kNi;k+) 13 *found* 14 aki=akNi 一 1= 【3】 ; 15 16 17 main() 18 int xNN=0),i,j; 19 fun(x); 20

3、 printf(“nThe result is:n“); 21 for(i=0;iN;i+) 22 for(j=0;jN;j+) 23 printf(“3d“,xij); 24 printf(“n“); 25 26 (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.假定整数数列中的数不重复,并存放在数组中。下列给定程序中函数 fun的功能是:删除数列中值为 x的元素,变量 n中存放数列中元素的个数。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdioh#define N 2 0fun

4、(int*a,int n,int x) int p=0,i; an=x; while(x!=aP) P=P+1;*found* if(P=n) return1; else for(i=P;in;i+)*found* ai+1=ai; return n1; void main() int wN=3,0,1,5,7,99,10,15,30,90),x,n,i ; n=10; printf(“The original data:n“); for(i=0;in;i+) printf(“5d“,wi); printf(“nInput x(to delere):“); scanf(“d“,x); prin

5、tf(“Delete:dn“,x); n=fun(w,n,x); if(n=1) printf(“*No be found!*nn“); else printf(“The data after deleted:n“); for(i=0 ; in;i+) printf(“5d“,wi); printf(“nn“); (分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.编写程序,实现矩阵(3 行、3 列)的转置(即行列互换)。例如,若输入下面的矩阵:100 200 300400 500 600700 800 900则程序输出:100 400 700200 500 800300 60

6、0 900 注意:部分源程序在文件PROG1C 中。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:1 #includestdioh2 #includeconioh3 #includestdlibh4 void fun(int array33)5 67 8 void main()9 10 FILE,lc Wf;11 int i,j;12 int array33=100,200,300),400,500,600),700,800,900);13 system(“CLS“);14 for(i=0;i3;i+)15 for(j=0;j3;J+

7、)16 printf(“7d“,arrayij);17 printf(“n“);18 19 fun(array);20 printf(“Converted array:n“);21 for(i=0;i3;i+)22 for(j=0;j3;j+)23 printf(“7d“,arrayij);24 printf(“n“);25 26 *found*27 wf=fopen(”outdat”,”w”);28 for(i=0;i3;i+)29 for(j=0;j3;j+)30 fprintf(wf,“7d“,arrayij);31 fprintf(wf,“n“);32 33 fclose(wf);34

8、 *found*35 (分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 269答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.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 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK

9、1C 中。 不得增行或删行,也不得更改程序的结构! 试题程序: 1 #includestdioh 2 #defitie N 7 3 *found* 4 void fun(int(*a) 【1】 ) 5 int i,j,k,m; 6 if(N2=0)m=N2; 7 else m=N2+1; 8 for(i=0;im;i+) 9 *found* 10 for(j= 【2】 ;jN i;j+) 11 aij=aNi 一 1j=i+1; 12 for(k=i+1;kNi;k+) 13 *found* 14 aki=akNi 一 1= 【3】 ; 15 16 17 main() 18 int xNN=0

10、),i,j; 19 fun(x); 20 printf(“nThe result is:n“); 21 for(i=0;iN;i+) 22 for(j=0;jN;j+) 23 printf(“3d“,xij); 24 printf(“n“); 25 26 (分数:2.00)_正确答案:(正确答案:(1)N (2)i (3)i+1)解析:解析:填空 1:本题考查了形参的确定。参数传递时将实参的值赋给形参,实参和形参是一一对应的,因此该空应该填写N。 填空 2:第二重 for循环中 aij和 aNi1j表示第一行和最后一行数组 aNN的值,因而此空应该填写 i。 填空 3:第三重 for循环代表的

11、是 aNN中每一列的值,因此此空应该填写 i+1。二、程序修改题(总题数:1,分数:2.00)2.假定整数数列中的数不重复,并存放在数组中。下列给定程序中函数 fun的功能是:删除数列中值为 x的元素,变量 n中存放数列中元素的个数。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdioh#define N 2 0fun(int*a,int n,int x) int p=0,i; an=x; while(x!=aP) P=P+1;*found* if(P=n) return1; else for(i=P

12、;in;i+)*found* ai+1=ai; return n1; void main() int wN=3,0,1,5,7,99,10,15,30,90),x,n,i ; n=10; printf(“The original data:n“); for(i=0;in;i+) printf(“5d“,wi); printf(“nInput x(to delere):“); scanf(“d“,x); printf(“Delete:dn“,x); n=fun(w,n,x); if(n=1) printf(“*No be found!*nn“); else printf(“The data af

13、ter deleted:n“); for(i=0 ; in;i+) printf(“5d“,wi); printf(“nn“); (分数:2.00)_正确答案:(正确答案:(1)if(p=n)return1; (2)ai=ai+1;)解析:解析:(1)需要确定 if条件语句的条件表达式,发现变量 p大写,C 语言中变量是区别大小写的。 (2)删除数列中的元素,删除后,后面的元素依次前移一个位置,因此此处应为 ai=ai+1;三、程序设计题(总题数:1,分数:2.00)3.编写程序,实现矩阵(3 行、3 列)的转置(即行列互换)。例如,若输入下面的矩阵:100 200 300400 500 60

14、0700 800 900则程序输出:100 400 700200 500 800300 600 900 注意:部分源程序在文件PROG1C 中。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:1 #includestdioh2 #includeconioh3 #includestdlibh4 void fun(int array33)5 67 8 void main()9 10 FILE,lc Wf;11 int i,j;12 int array33=100,200,300),400,500,600),700,800,900);13 s

15、ystem(“CLS“);14 for(i=0;i3;i+)15 for(j=0;j3;J+)16 printf(“7d“,arrayij);17 printf(“n“);18 19 fun(array);20 printf(“Converted array:n“);21 for(i=0;i3;i+)22 for(j=0;j3;j+)23 printf(“7d“,arrayij);24 printf(“n“);25 26 *found*27 wf=fopen(”outdat”,”w”);28 for(i=0;i3;i+)29 for(j=0;j3;j+)30 fprintf(wf,“7d“,a

16、rrayij);31 fprintf(wf,“n“);32 33 fclose(wf);34 *found*35 (分数:2.00)_正确答案:(正确答案:Void fun(int array33) int i,j,t; for(i=0;i3;i+)*将右上三角和左下三角对换,实现行列互换* for(j=i+1;j3;j+) t=arrayij; arrayij=arrayji; arrayij=arrayij; arrayji=t; )解析:解析:要实现矩阵转置,即将右上角数组元素和左下角数组元素对换,本题通过数组元素交换方法,完成矩阵转置操作。 因为对矩阵转置后仍然存回其本身,所以只能循环矩阵中的一个角(本程序是右上半三角)。控制右上半三角的方法是在内层循环中循环变量 j从 i+1或 i开始。

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