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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C语言机试(操作题)模拟试卷 401及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:有 NN矩阵,根据给定的 m(m=)值,将每行元素中的值均右移 m个位置,左边置为 0。例如,N=3,m=2,有下列矩阵 1 2 3 4 5 6 7 8 9 程序执行结果为 0 0 l 0 0 4 0 0 7 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #defi

2、ne N 43 void fun(int(*t)N,int m)4 int i,j;5 *found*6 for(i=0;iN;_1_ )7 for(j=N-1-m;j=0;j-)8 *found*9 tij+_2_=tij;10 *found*11 for(j=0;j_3_;j+)12 tij=0;13 1415 main()16 int tN=21,12,13,24,25,16,47,38,29,11,32,54,42,21,33,10,i, j, m;17 printf(nThe original array:n);18 for(i=0; iN; i+)19 for(j=0;jN;j+)

3、20 printf(2d,tij);21 printf(n);22 23 printf(Input m(m=d) :,N);scanf(d,25 printf(nThe result is:n);26 for(2=0;iN;i+)27 for(j=0;jN;j+)28 printf(2d,tij);29 printf(n);30 31 (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中的函数 Creatlink的功能是创建带头结点的单向链表,并为各结点数据域赋 0到m-1的值。 请改正函数 Creatlink中指定部位的错误,使它能得出正确的结果。

4、注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #includestdlibh3 typedef struct aa4 int data;5 struct aa *next;6 NODE;7 NODE *Creatlink(int n,int m)8 NODE * h=NULL,*p,*s;9 int i;10 *found*11 p=(NODE)malloc(sizeof(NODE);12 h=p;13 p-next=NULL;14 for(i=1;i=n;i+)15 s=(NODE *)malloc(sizeof(NODE);16 s

5、data=rand()m; s-next=p-next;17 p-next=s;p=p-next;18 19 *found*20 return p;21 22 outlink(NODE *h)23 NODE *p;24 p=h-next;25 printf(nXnTHE LIST:nn HEAD);26 while(p)27 printf(-d,p-data);28 p=p-next;29 30 printf(n);31 main()32 NODE *head;33 head=Creatlink(8,22);34 outlink(head);(分数:2.00)_三、程序设计题(总题数:1,分

6、数:2.00)3.请编写函数 fun,函数的功能是:将 M行 N列的二维数组中的数据,按列的顺序依次放到一维数组中。 例如,二维数组中的数据为: 33 33 33 33 44 44 44 44 55 55 55 55 则一维数组中的内容应是: 33 44 55 33 44 55 33 44 55 33 44 55。 注意:部分源程序在文件 PROGlC 中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。1 #includestdioh2 void fun(int s10,int b,int*n,int mm,int nn)3 4 5 main

7、)6 int w1010=33,33,33,33,44,44,44,44,55,55,55,55,i,j;7 int a100=(0),n=0;void NONO();8 printf(The matrix:n);9 for(i=0; i3;i+)10 for(j=0;j4;j+) printf(3d,wij);11 printf(n);12 fun(w,a,n,3,4);13 printf(The A array:n);14 for(i=0;in;i+) printf(3d,ai);printf(nn);15 NONO();16 void NONO()17 *请在此函数内打开文件,输入测试

8、数据,调用 fun函数,输出数据,关闭文件。 *18 FILE *rf,*wf;int i,j,k;19 int w1010,a100,n=0,mm,nn;20 rf=fopen(indat,r);21 wf=fopen(outdat,w);22 for(k=0;k5;k+)23 fscanf(rf,dd, jnn ; j+) fscanf(rf,d,wij);26 fun(w,a,n,mm,nn);27 for(i=0;in;i+) fprintf(wf,3d,ai); fprintf(wf,n);28 29 fclose(rf);fclose(wf);(分数:2.00)_国家二级 C语言机

9、试(操作题)模拟试卷 401答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:有 NN矩阵,根据给定的 m(m=)值,将每行元素中的值均右移 m个位置,左边置为 0。例如,N=3,m=2,有下列矩阵 1 2 3 4 5 6 7 8 9 程序执行结果为 0 0 l 0 0 4 0 0 7 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #define N 43 vo

10、id fun(int(*t)N,int m)4 int i,j;5 *found*6 for(i=0;iN;_1_ )7 for(j=N-1-m;j=0;j-)8 *found*9 tij+_2_=tij;10 *found*11 for(j=0;j_3_;j+)12 tij=0;13 1415 main()16 int tN=21,12,13,24,25,16,47,38,29,11,32,54,42,21,33,10,i, j, m;17 printf(nThe original array:n);18 for(i=0; iN; i+)19 for(j=0;jN;j+)20 printf(

11、2d,tij);21 printf(n);22 23 printf(Input m(m=d) :,N);scanf(d,25 printf(nThe result is:n);26 for(2=0;iN;i+)27 for(j=0;jN;j+)28 printf(2d,tij);29 printf(n);30 31 (分数:2.00)_正确答案:(正确答案:(1)i+ (2)m (3)m)解析:解析:函数 fun的功能是将每行元素中的值均右移 m个位置。 第一空:题目要求对每行元素中的值均右移 m个位置,故第一空处循环变量每次增 1,共循环 N次,完成对 N行的移位操作,因此第一空处应为“i+

12、 第二空:循环“for(j=N-1-m;j=0;j-)”是进行行元素中的值右移 m个位置,即把tij元素放置在 tij+m上,因此第二空应为“m”。 第三空:循环“for(j=0;j_3_;j+)”是对空出来的位置补 0,每行元素的前 m位数据已经移动到后面,每行空处 m个元素,因此第三空为“m”。二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中的函数 Creatlink的功能是创建带头结点的单向链表,并为各结点数据域赋 0到m-1的值。 请改正函数 Creatlink中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更

13、改程序的结构!1 #includestdioh2 #includestdlibh3 typedef struct aa4 int data;5 struct aa *next;6 NODE;7 NODE *Creatlink(int n,int m)8 NODE * h=NULL,*p,*s;9 int i;10 *found*11 p=(NODE)malloc(sizeof(NODE);12 h=p;13 p-next=NULL;14 for(i=1;i=n;i+)15 s=(NODE *)malloc(sizeof(NODE);16 s-data=rand()m; s-next=p-nex

14、t;17 p-next=s;p=p-next;18 19 *found*20 return p;21 22 outlink(NODE *h)23 NODE *p;24 p=h-next;25 printf(nXnTHE LIST:nn HEAD);26 while(p)27 printf(-d,p-data);28 p=p-next;29 30 printf(n);31 main()32 NODE *head;33 head=Creatlink(8,22);34 outlink(head);(分数:2.00)_正确答案:(正确答案:(1)p=(NODE*)malloc (sizeof(NODE

15、); (2)return h;)解析:解析:(1)“p=(NODE)malloc(sizeof(NODE);”第一标识,maclloc 函数的返回类型是 void*类型,表示未确定类型的指针,因此需要指针类型转换,而“(NODE)”不是指针类型,故第一标识下应改成“p=(NODE*)malloc(sizeof(NODE);”。 (2)第二个标识下,最后将单链表返回,应该是返回头指针 h指向的链表,而不是其中的一个节点 p,所以“return p;”应该改为“return h;”。三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,函数的功能是:将 M行 N列的二维数组中的数据,

16、按列的顺序依次放到一维数组中。 例如,二维数组中的数据为: 33 33 33 33 44 44 44 44 55 55 55 55 则一维数组中的内容应是: 33 44 55 33 44 55 33 44 55 33 44 55。 注意:部分源程序在文件 PROGlC 中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。1 #includestdioh2 void fun(int s10,int b,int*n,int mm,int nn)3 4 5 main()6 int w1010=33,33,33,33,44,44,44,44,55,55

17、55,55,i,j;7 int a100=(0),n=0;void NONO();8 printf(The matrix:n);9 for(i=0; i3;i+)10 for(j=0;j4;j+) printf(3d,wij);11 printf(n);12 fun(w,a,n,3,4);13 printf(The A array:n);14 for(i=0;in;i+) printf(3d,ai);printf(nn);15 NONO();16 void NONO()17 *请在此函数内打开文件,输入测试数据,调用 fun函数,输出数据,关闭文件。 *18 FILE *rf,*wf;int

18、 i,j,k;19 int w1010,a100,n=0,mm,nn;20 rf=fopen(indat,r);21 wf=fopen(outdat,w);22 for(k=0;k5;k+)23 fscanf(rf,dd, jnn ; j+) fscanf(rf,d,wij);26 fun(w,a,n,mm,nn);27 for(i=0;in;i+) fprintf(wf,3d,ai); fprintf(wf,n);28 29 fclose(rf);fclose(wf);(分数:2.00)_正确答案:(正确答案:1 int i,j; 2 for(j=0 ; jnn;j+) 3 for(i=0;imm;i+) 4 b*n=*(*(s+i)+j); 5 *n=*n+1; )解析:解析:(1)利用两重循环,依次取矩阵中的元素。 (2)其中注意指针数组与数组指针的区别,其中数组指针 s,它指向包含 4个元素的一维数组。其数据元素的表示方式为:“*(*c(s+i)+j)”。

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