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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C语言机试(操作题)模拟试卷 303及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.下列给定程序中,函数 fun的功能是:在带头结点的单向链表中,查找数据域中值为 ch的结点。找到后通过函数值返回该结点在链表中所处的顺序号;若不存在值为 ch的结点,函数返回 0值。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构! 试题程序: #includestdioh #includestdlibh #define N 8 typedef struer li

2、St int data; struct list *next; SLIST; SLIST*creatlist(char*); void outlist(SLIST*); int fun(SLIST*h,char ch) SLIST*P; int n=0; P=hnext ; *found* while(p!= 【1】 ) n+; *found* if(Pdata=ch) return 【2】 ; else P=Pnext; return 0; main() SLIST*head;int k;char ch;char aN=m,p,g,a,w,x,r,d;head=creatlist(a); o

3、utliSt(head); printf(“Enter a letter:“); scanf(“c“,ch); *found* k=fun( 【3】 ); if(k=0) printf(“nNot found!n“); else printf(“The sequence number is:dn“,k); SLIST*creatlist(char*a) SLIST*h,*p,*q;int i; h=p=(SLIST*)malloc(sizeof(SLIST); for(i=0;iN;i+) q=(SLIST*)malloc(sizeof(SLIST); qdata=ai;Pnext=q; p=

4、q; Pnext=0; return h; void outlist(SLIST*h) SLIST*P; P=hnext; if(P=NULL) printf(“nThe list is NULL!n“);else printf(“nHead“); do printf(“C“, pdata);p=pnext; while(P!=NULL);printf(“Endn“”); (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.下列给定程序中函数 fun的功能是:将 m(1m10)个字符串连接起来,组成一个新串,放入 pt所指存储区中。例如:把三个串“abc”、“CD”、“EF”连

5、接起来,结果是“abcCDEF”。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序: #includestdioh #includestringh void fun(char sir10, int m,char*pt) *found* Tnt k,q,i; for(k=0;km;k+) q=strlen(sirk); for(i=0 j iq;i+) *found* pti=strk,i; pt+=q; pt0=0; main() int m,h; char s1010,P120; printf(“Please enter

6、m:”); scanf(“d”,m),gets(s0),printf(“Please enterd string:”,m); for(h=0;hm;h+)gets(sh); fun(s,m,p); printf(“The result is:s”, p);(分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.已知学生的记录由学号和学习成绩构成,N 名学生的数据已存入 a结构体数组中。请编写函数 fun,该函数的功能是:找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。已给出函数的首部,请完成该函数。注意:部分源程序给出如下。请勿改动主函数 nmin和其他函数中的任

7、何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#includestdlibh#includestdioh#includestringh#includeconioh#defitie N 10 typedef struct ss *定义结构体* char num10; int s;STU;fun(STU a,STU *s)void main() STU aN=“A01“,81,“A02“,89,“A03“,66,“A04“,87,“A0 5“,77,“A06“,90,“A07“,79,“A08“,61,“A09“,80),“A10“,71,m; int i ; system(“

8、CLS“);printf(“*The original data*“); for(i=0;iN;i+) printf(“No=s Mark=dn“,ainum,ais); fun(a,m); printf(“*THE RESULT*n“); printf(“The top:s,dn“,mnum,ms);(分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 303答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.下列给定程序中,函数 fun的功能是:在带头结点的单向链表中,查找数据域中值为 ch的结点。找到后通过函数值返回该结点在链表中所处的顺

9、序号;若不存在值为 ch的结点,函数返回 0值。 请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构! 试题程序: #includestdioh #includestdlibh #define N 8 typedef struer liSt int data; struct list *next; SLIST; SLIST*creatlist(char*); void outlist(SLIST*); int fun(SLIST*h,char ch) SLIST*P; int n=0; P=hnext ; *

10、found* while(p!= 【1】 ) n+; *found* if(Pdata=ch) return 【2】 ; else P=Pnext; return 0; main() SLIST*head;int k;char ch;char aN=m,p,g,a,w,x,r,d;head=creatlist(a); outliSt(head); printf(“Enter a letter:“); scanf(“c“,ch); *found* k=fun( 【3】 ); if(k=0) printf(“nNot found!n“); else printf(“The sequence num

11、ber is:dn“,k); SLIST*creatlist(char*a) SLIST*h,*p,*q;int i; h=p=(SLIST*)malloc(sizeof(SLIST); for(i=0;iN;i+) q=(SLIST*)malloc(sizeof(SLIST); qdata=ai;Pnext=q; p=q; Pnext=0; return h; void outlist(SLIST*h) SLIST*P; P=hnext; if(P=NULL) printf(“nThe list is NULL!n“);else printf(“nHead“); do printf(“C“,

12、 pdata);p=pnext; while(P!=NULL);printf(“Endn“”); (分数:2.00)_正确答案:(正确答案:1)NULL (2)n (3)head,ch)解析:解析:填空 1:while 循环语句用来判断是否到达链表结尾,链表结尾结点指针域是 NULL。 填空2:若找到指定字符,则通过 return语句将该结点在链表的顺序号返回给 main函数。 填空 3:函数调用语句,其形式是:函数名(实际参数表),因此根据函数定义语句,填入 head,ch。二、程序修改题(总题数:1,分数:2.00)2.下列给定程序中函数 fun的功能是:将 m(1m10)个字符串连接起来

13、,组成一个新串,放入 pt所指存储区中。例如:把三个串“abc”、“CD”、“EF”连接起来,结果是“abcCDEF”。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序: #includestdioh #includestringh void fun(char sir10, int m,char*pt) *found* Tnt k,q,i; for(k=0;km;k+) q=strlen(sirk); for(i=0 j iq;i+) *found* pti=strk,i; pt+=q; pt0=0; main() int

14、m,h; char s1010,P120; printf(“Please enter m:”); scanf(“d”,m),gets(s0),printf(“Please enterd string:”,m); for(h=0;hm;h+)gets(sh); fun(s,m,p); printf(“The result is:s”, p);(分数:2.00)_正确答案:(正确答案:(1)int k,q,i; (2)pti=strki;)解析:解析:本题考查:C 语言的书写和语法性错误,这类错误比较简单,只要编译程序,根据错误提示修改即可。 (1)关键字书写错误,定义整型变量的关键字应使用 in

15、t,而非 Int。 (2)数组元素表示错误,表示二维数组元素,应使用方括号将行坐标和列坐标分别括起来,即 strk,i应改为:strki。三、程序设计题(总题数:1,分数:2.00)3.已知学生的记录由学号和学习成绩构成,N 名学生的数据已存入 a结构体数组中。请编写函数 fun,该函数的功能是:找出成绩最高的学生记录,通过形参返回主函数(规定只有一个最高分)。已给出函数的首部,请完成该函数。注意:部分源程序给出如下。请勿改动主函数 nmin和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#includestdlibh#includestdioh#includ

16、estringh#includeconioh#defitie N 10 typedef struct ss *定义结构体* char num10; int s;STU;fun(STU a,STU *s)void main() STU aN=“A01“,81,“A02“,89,“A03“,66,“A04“,87,“A0 5“,77,“A06“,90,“A07“,79,“A08“,61,“A09“,80),“A10“,71,m; int i ; system(“CLS“);printf(“*The original data*“); for(i=0;iN;i+) printf(“No=s Mark

17、=dn“,ainum,ais); fun(a,m); printf(“*THE RESULT*n“); printf(“The top:s,dn“,mnum,ms);(分数:2.00)_正确答案:(正确答案:fun(STU a,STU*s) int i; *s=a0; for(i=0;iN;i+) *找出成绩最高的学生记录* if(ssais) *s=ai; )解析:解析:本题的流程是先使 s指向第 1名学生,利用循环语句遍历所有学生的成绩,利用条件语句判断当前学生成绩是否最高,所以 if语句的条件是 ssais。此外,做题时应该熟练掌握“指向运算符”和“成员运算符”的相关知识,题中“ss”等价于“(*s)s”。

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