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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C语言机试(操作题)模拟试卷 317及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.下列给定程序中,函数 fun的功能是:统计带头结点的单向链表中结点的个数,并存放在形参 n所指的存储单元中。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构! 试题程序: #includestdioh #includestdlibh #defitie N 8 typedef struct list int data; struer list*next; SLIST

2、 SLIST*creatlist(int *a); void outlist(SLIST*); void fun(SLTST*h,int*n) SLIST*P; *found* 【1】 =0; P=hnext; while(P) (*n)+; *found* p=P 【2】 ; main() SLIST*head; int aN=12,87,45,32,91, 16,20,48),num; head=creatlist(a); outlist(head); *found* fun( 【3】 ,&hum); printf(“nnumber=dn“,num); SLIST*creatlist(i

3、nt a) SLIST*h,*P,*q; int i; h=P=(SLIST*)malloc(sizeof(SLIST); for(i=0;iN;i+) q=(SLIST*)malloc(sizeof(SLTST); qdata=ai;Pnext=q; p=q; Pnext=0; return h; void outlist(SLTST*h) SLIST*P; P=hnext; if(P=NULL) printf(“The list is NULL!n“); else printf(“nHead“); do printf(“d“,pdata);p=Pnext;) while(P!=NULL);

4、 printf(“Endn“); (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数 fun的功能是将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并且作为函数值返回。请改正函数 fun中的错误,使它能得出正确的结果。注意:部分源程序在文件 MODI1C 中,不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdioh#includeconioh#includestdlibhtypedef struct aa int data; struct aa *nex

5、t; NODE;int fun(NODE * h) int sum=0; NODE *P; P=hnext;*found* while(Pnext) if(Pdata2=0) sum+=pdata;*found* P=hnext; return sum;NODE*treatlink(int n) NODE*h,*p,*s; int i ; h=P=(NODE*)malloc(sizeof(NODE); for(i=1;in;i+) S=(NODE*)malloc(sizeof(NODE); Sdata=rand()16; Snext=Pnext; Pnext=s; p=pnext; pnext

6、NULL; return h; outlink(NODE*h) NODE*P; P=hnext; printf(“nn The LIST:nnHEAD“); while(p) printf(“d“,Pdata); P=Pnext; printf(“n“);void main() NODE*head; int sum; system(“CLS“); head=creatlink(10); outlink(head); sum=fun(head); printf(“nsum=d“,sum);(分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.函数 fun的功能是:将 s所指字符串

7、中下标为偶数同时 ASCII值为奇数的字符删除,s 所指串中剩余的字符形成的新串放在 t所指的数组中。例如,若 s所指字符串中的内容为”ABCDEFG12345”,其中字符 C的 ASCII码值为奇数,在数组中的下标为偶数,因此必须删除;而字符 1的 ASCII码值为奇数,在数组中的下标为奇数,因此不应当删除,其他依此类推。最后 t所指的数组中的内容应是“BDFl2345“。注意:部分源程序在文件 PROG1C 中。请勿改动 main函数和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#includestdioh#includestringhvoid fun(

8、char*,char t)main() char s100,t100;void NONO(); printf(“nPlease enter string S:“); scanf(“s“,s); fun(s,t); printf(“nThe result is:sn“,t); NONO();void NONO()*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。* char S100,t100; FILE* rf,(wf; int i; rf=fopen(“indat“,“r“); wf=fopen(“outdat“,“W“); for(i=0;i10;i+) fscanf(rf,“

9、s“,s); fun(s,t); fprintf(wf,“sn“,t); fclose(rf); fclose(wf); (分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 317答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.下列给定程序中,函数 fun的功能是:统计带头结点的单向链表中结点的个数,并存放在形参 n所指的存储单元中。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构! 试题程序: #includestdioh #includestdl

10、ibh #defitie N 8 typedef struct list int data; struer list*next; SLIST; SLIST*creatlist(int *a); void outlist(SLIST*); void fun(SLTST*h,int*n) SLIST*P; *found* 【1】 =0; P=hnext; while(P) (*n)+; *found* p=P 【2】 ; main() SLIST*head; int aN=12,87,45,32,91, 16,20,48),num; head=creatlist(a); outlist(head)

11、 *found* fun( 【3】 ,&hum); printf(“nnumber=dn“,num); SLIST*creatlist(int a) SLIST*h,*P,*q; int i; h=P=(SLIST*)malloc(sizeof(SLIST); for(i=0;iN;i+) q=(SLIST*)malloc(sizeof(SLTST); qdata=ai;Pnext=q; p=q; Pnext=0; return h; void outlist(SLTST*h) SLIST*P; P=hnext; if(P=NULL) printf(“The list is NULL!n“)

12、 else printf(“nHead“); do printf(“d“,pdata);p=Pnext;) while(P!=NULL); printf(“Endn“); (分数:2.00)_正确答案:(正确答案:(1)*n (2)next (3)head)解析:解析:填空 1:*n 用来存放结点的个数,对其赋初值为 0。 填空 2:while 循环用于遍历链表,循环一次,指针指向链表的下一个结点。 填空 3:根据函数定义语句确定调用函数的实际参数,即fun(head,&num);。二、程序修改题(总题数:1,分数:2.00)2.下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点

13、赋值。函数 fun的功能是将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并且作为函数值返回。请改正函数 fun中的错误,使它能得出正确的结果。注意:部分源程序在文件 MODI1C 中,不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdioh#includeconioh#includestdlibhtypedef struct aa int data; struct aa *next; NODE;int fun(NODE * h) int sum=0; NODE *P; P=hnext;*found* while(Pnext) if(Pdat

14、a2=0) sum+=pdata;*found* P=hnext; return sum;NODE*treatlink(int n) NODE*h,*p,*s; int i ; h=P=(NODE*)malloc(sizeof(NODE); for(i=1;in;i+) S=(NODE*)malloc(sizeof(NODE); Sdata=rand()16; Snext=Pnext; Pnext=s; p=pnext; pnext=NULL; return h; outlink(NODE*h) NODE*P; P=hnext; printf(“nn The LIST:nnHEAD“); wh

15、ile(p) printf(“d“,Pdata); P=Pnext; printf(“n“);void main() NODE*head; int sum; system(“CLS“); head=creatlink(10); outlink(head); sum=fun(head); printf(“nsum=d“,sum);(分数:2.00)_正确答案:(正确答案:(1)while(p!=NULL) (2)p=pnext;)解析:解析:(1)判断当前指针 p指向的结点是否存在,若存在则对该结点数据域进行判断操作。 (2)判断结束后指针指向下一个结点。三、程序设计题(总题数:1,分数:2.0

16、0)3.函数 fun的功能是:将 s所指字符串中下标为偶数同时 ASCII值为奇数的字符删除,s 所指串中剩余的字符形成的新串放在 t所指的数组中。例如,若 s所指字符串中的内容为”ABCDEFG12345”,其中字符 C的 ASCII码值为奇数,在数组中的下标为偶数,因此必须删除;而字符 1的 ASCII码值为奇数,在数组中的下标为奇数,因此不应当删除,其他依此类推。最后 t所指的数组中的内容应是“BDFl2345“。注意:部分源程序在文件 PROG1C 中。请勿改动 main函数和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#includestdioh#

17、includestringhvoid fun(char*,char t)main() char s100,t100;void NONO(); printf(“nPlease enter string S:“); scanf(“s“,s); fun(s,t); printf(“nThe result is:sn“,t); NONO();void NONO()*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。* char S100,t100; FILE* rf,(wf; int i; rf=fopen(“indat“,“r“); wf=fopen(“outdat“,“W“); for(i=0;i10;i+) fscanf(rf,“s“,s); fun(s,t); fprintf(wf,“sn“,t); fclose(rf); fclose(wf); (分数:2.00)_正确答案:(正确答案:Void fun(char*s,char t) int i,j =0, for(i=0;istrlen(s);i+) if(!(i2)=0(si2) tj+=si; tj=0; )解析:解析:本题是从一个字符串按要求生成另一个新的字符串。我们使用 for循环语句来解决这个问题。在赋值新的字符串之前,先对数组元素的下标和 ASCII码的值进行判断,将满足要求的元素赋给新的字符串。

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