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

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

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

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

    【计算机类职业资格】国家二级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)”。


    注意事项

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




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

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

    收起
    展开