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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C语言机试(操作题)模拟试卷 423及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是: 用函数指针指向要调用的函数,并进行调用。 规定在 【2】 处使f指向函数 f1,在 【3】 处使 f指向函数 f2。 当调用正确时,程序输出: x1=5000000,x2=3000000,x1*x1+x1*x2= 40000000。 注意:部分源程序在文件 BLANK1C 中。 不得增行或删行,也不得更改程序的结构! 试题程序: #include stdio h double f1 (double x) return

2、 x*x; double f2 (double x, double y) return x*y; double fun (double a, double b) /*found*/ 【1】 (*f)(); double r1, r2; /*found*/ f= 【2】 ; r1=f(a); /*found*/ f= 【3】 ; r2=(*f)(a,b); return r1 + r2; main () double x1 =5, x2 =3, r, r = fun (xl, x2); printf (“/nx1 = f, x2 = f, x1 * x1 +x1 * x2 = f/n“,x1,

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

4、 next; NODE;int fun (NODE*h) int sum =0; NODE *p; p = h 一 next;/*found*/ while (p 一 next) if (p 一 data 2 =0) sum += p 一 data;/*found*/ p = h 一 next; return sum;NODE * creatlink (int n) NODE *h, *p, * s; int i; h=p=(NODE * ) malloc ( sizeof(NODE); for(i=1,i n ; i+) s=(NODE * ) malloc ( sizeof(NODE);

5、 s 一 data = rand () 16; s 一 next =p 一 next; p 一 next = s; p =p 一 next; p 一 next = NULL; return h;outlink (NODE*h) NODE *p; p= h 一 next; printf (“/n/n The LIST :/n/nHEAD“) ; while (p) printf (“一 d“,p 一 data) ; p =p 一 next; printf “/n“) ; void main () NODE *head; int sum; system ( “CLS“) ; head = crea

6、tlink (10) ; outlink (head) ; sum = fun (head) ; printf ( “ /nSUM = d“, sum) ;(分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun,该函数的功能是:判断字符串是否为回文,若是,则函数返回 1,主函数中输出”YES”,否则返回 0,主函数中输出” NO”。回文是指顺读和倒读都一样的字符串。 例如,字符串 LEVEL是回文,而字符串 123312就不是回文。 注意:部分源程序在文件 PROG1C 中。 请勿改动主函数 maln和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的

7、若干语句。试题程序:#include stdio h #define N 80int fun (char * str)main () char sN ; FILE * out; char * test =“1234321“,“123421“, “123321“, “abcdCBA“ ; int i; printf (“Enter a string : “); gets (s) ; printf (“/n/n“) ; puts (s) ; if (fun (s) printf (“YES/n“) ; else printf (“NO/n“) ;/*/ out = fopen (“outdat“w

8、) ; if (fun (testi ) fprintf (out, “YES/n“) ; else fprintf (out, “NO/n“) ; fclose (out) ;/*/ (分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 423答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是: 用函数指针指向要调用的函数,并进行调用。 规定在 【2】 处使f指向函数 f1,在 【3】 处使 f指向函数 f2。 当调用正确时,程序输出: x1=5000000,x2=3000000,x1*x1+x1*x2=

9、40000000。 注意:部分源程序在文件 BLANK1C 中。 不得增行或删行,也不得更改程序的结构! 试题程序: #include stdio h double f1 (double x) return x*x; double f2 (double x, double y) return x*y; double fun (double a, double b) /*found*/ 【1】 (*f)(); double r1, r2; /*found*/ f= 【2】 ; r1=f(a); /*found*/ f= 【3】 ; r2=(*f)(a,b); return r1 + r2; ma

10、in () double x1 =5, x2 =3, r, r = fun (xl, x2); printf (“/nx1 = f, x2 = f, x1 * x1 +x1 * x2 = f/n“,x1, x2, r) ; (分数:2.00)_正确答案:(正确答案:(1)double (2)f1 (3)f2)解析:解析:填空 1:(*f)()代表一个指向函数的指针变量,而本题所被调用的 f1、f2 两函数的返回值均为 double型,因而此空应该填写 double。 填空 2:因为在给函数指针变量赋值时,只需给出函数名而不必给出参数,因而此空应该填写 f1。 填空 3:同填空 2,此空应该填写

11、 f2。 相关知识点: (1)指向函数的指针变量的一般定义形式为:数据类型(*指针变量名)(); (2)函数的调用可以通过函数名调用,也可以通过函数指针调用。 (3)在给函数指针变量赋值时,只需给出函数名而不必给出参数。二、程序修改题(总题数:1,分数:2.00)2.下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数 fun的功能是将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并且作为函数值返回。 请改正函数 fun中的错误,使它能得出正确的结果。 注意:部分源程序在文件 MODI1C 中,不要改动 maln函数,不得增行或删行,也不得更改程序的结构! 试题程序

12、include stdio h #include conio h #include stcilibh typedef struct aa int data; struct aa * next; NODE;int fun (NODE*h) int sum =0; NODE *p; p = h 一 next;/*found*/ while (p 一 next) if (p 一 data 2 =0) sum += p 一 data;/*found*/ p = h 一 next; return sum;NODE * creatlink (int n) NODE *h, *p, * s; int i

13、 h=p=(NODE * ) malloc ( sizeof(NODE); for(i=1,i n ; i+) s=(NODE * ) malloc ( sizeof(NODE); s 一 data = rand () 16; s 一 next =p 一 next; p 一 next = s; p =p 一 next; p 一 next = NULL; return h;outlink (NODE*h) NODE *p; p= h 一 next; printf (“/n/n The LIST :/n/nHEAD“) ; while (p) printf (“一 d“,p 一 data) ;

14、p =p 一 next; 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=p 一 next;)解析:解析:(1)判断当前指针 p指向的结点是否存在,若存在则对该结点数据域进行判断操作。 (2)判断结束后指针指向下一个结点。三、程序设计题(总题数:

15、1,分数:2.00)3.请编写函数 fun,该函数的功能是:判断字符串是否为回文,若是,则函数返回 1,主函数中输出”YES”,否则返回 0,主函数中输出” NO”。回文是指顺读和倒读都一样的字符串。 例如,字符串 LEVEL是回文,而字符串 123312就不是回文。 注意:部分源程序在文件 PROG1C 中。 请勿改动主函数 maln和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#include stdio h #define N 80int fun (char * str)main () char sN ; FILE * out; char * test

16、 =“1234321“,“123421“, “123321“, “abcdCBA“ ; int i; printf (“Enter a string : “); gets (s) ; printf (“/n/n“) ; puts (s) ; if (fun (s) printf (“YES/n“) ; else printf (“NO/n“) ;/*/ out = fopen (“outdat“w“) ; if (fun (testi ) fprintf (out, “YES/n“) ; else fprintf (out, “NO/n“) ; fclose (out) ;/*/ (分数:2.

17、00)_正确答案:(正确答案:int fun(char*str) int i,n =0, fg =1; char *p=str; while(*p)/*将指针 p置位到字符串末尾,并统计字符数*/ n+; p+; for(i=0;i n/2;i+)/*循环比较字符*/ if (stri=strn 一 1一 1); /*相同,什么都不作*/ else/*不同,直接跳出循环*/ fg=0; break; return fg; )解析:解析:判断圆文就是将第一个字符与最后一个字符比较,第二个字符与倒数第二个字符进行比较,依此类推,直到中间的字符,如果比较的结果都相同,那么这个字符串就是回文,否则不是。程序中循环语句用来遍历字符串,条件语句用来判断当前字符与对应位置的字符是否相同。

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