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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C语言机试(操作题)模拟试卷 430及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:判断形参 s所指字符串是否是”回文”(Palindrome),若是,函数返回值为 1;不是,函数返回值为 0。”回文”是正读和反读都一样的字符串(不区分大小写字母)。 例如,LEVEL和 Level是”回文”,而 LEVLEV不是”回文”。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK1C 中。 不得增行或删行,也不得更改程序的结构! 试题程序: #incl

2、ude stdioh #include stringh #include ctypeh int fun(char*s) char*lp,*rp; /*found*/ lp= 【1】 ; rp=s+str1en(s)一1; while(toupper(* lp):=toupper (*rp)&(1p rp) /*found*/ lp+;rp 【2】 ;) /*found*/ if(1p rp) 【3】 ; else return 1; main() char s81; printf(“Enter a string:“); scar1f(“s“,s); if(fun(s) printf(“/n“s

3、“is a Palindrome/n/n“,s); else printf,“/ n|“s “isnt a palindrome/n/n“,s); (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.下列给定程序中,函数 fun的功能是:求出如下分数列的前 n项之和。 (分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.请编写一个函数 void fun(int m,intk,int xx),该函数的功能是:将大于整数 m且紧靠 m的 k个素数存入所指的数组中。 例如,若输入 17,5,则应输出 19、23、29、31、37。 注意:部分源程序在文件 PROG1C

4、 中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 试题程序:#incJude conioh #2nclude stdioh #include stdlibh void fun(int m,int k,int xx)void main() FTLE * wf; int m,n,zz1 0 0 0; system(“CLS“); printf“/nPlease enter two integers:“); scanf(“dd“,&m,&n); fun(m,n,z z); for(m=0;m n;m+) printf(“d“,zzm);prin

5、tf(“/n“);/*found*/ wf=fopen(“outdat“,“w“); fun(1 7,5,zz); for(m=0;m 5;m+) fprintf(wf,“d“,zzm); fclose(wf);/*found*/(分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 430答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.给定程序中,函数 fun的功能是:判断形参 s所指字符串是否是”回文”(Palindrome),若是,函数返回值为 1;不是,函数返回值为 0。”回文”是正读和反读都一样的字符串(不区分大小写字母)。 例如,

6、LEVEL和 Level是”回文”,而 LEVLEV不是”回文”。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件 BLANK1C 中。 不得增行或删行,也不得更改程序的结构! 试题程序: #include stdioh #include stringh #include ctypeh int fun(char*s) char*lp,*rp; /*found*/ lp= 【1】 ; rp=s+str1en(s)一1; while(toupper(* lp):=toupper (*rp)&(1p rp) /*found*/ lp+;rp 【2】 ;

7、) /*found*/ if(1p rp) 【3】 ; else return 1; main() char s81; printf(“Enter a string:“); scar1f(“s“,s); if(fun(s) printf(“/n“s“is a Palindrome/n/n“,s); else printf,“/ n|“s “isnt a palindrome/n/n“,s); (分数:2.00)_正确答案:(正确答案:(1)s (2)一一 (3)return 0)解析:解析:填空 1:根据函数体 fun中,对变量 lp和 rp的使用可知,lp 应指向形参 s的起始地址,rp指向

8、 s的结尾地址,所以应填 s。 填空 2:rp 是指向字符串的尾指针,当每做一次循环 rp向前前动一个位置,所以应填:一一。 填空 3:当 lp和 rp相等时,表示字符串是回文并返回 1,否则就返回 0,所以应填 retum 0。二、程序修改题(总题数:1,分数:2.00)2.下列给定程序中,函数 fun的功能是:求出如下分数列的前 n项之和。 (分数:2.00)_正确答案:(正确答案:(1)double fun(int n) (2)s=s+(double) a/b;)解析:解析:(1)由于返回值 s是 double型的,所以函数要定义为 double型。 (2)C 语言规定所有关键字都必须用

9、小写英文字母表示,所以 s=s+( Double) a/b;应改为 s=s+ (double) a/b;。三、程序设计题(总题数:1,分数:2.00)3.请编写一个函数 void fun(int m,intk,int xx),该函数的功能是:将大于整数 m且紧靠 m的 k个素数存入所指的数组中。 例如,若输入 17,5,则应输出 19、23、29、31、37。 注意:部分源程序在文件 PROG1C 中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。 试题程序:#incJude conioh #2nclude stdioh #include s

10、tdlibh void fun(int m,int k,int xx)void main() FTLE * wf; int m,n,zz1 0 0 0; system(“CLS“); printf“/nPlease enter two integers:“); scanf(“dd“,&m,&n); fun(m,n,z z); for(m=0;m n;m+) printf(“d“,zzm);printf(“/n“);/*found*/ wf=fopen(“outdat“,“w“); fun(1 7,5,zz); for(m=0;m 5;m+) fprintf(wf,“d“,zzm); fclos

11、e(wf);/*found*/(分数:2.00)_正确答案:(正确答案:void fun (int m,int k,int xx) int i,j,n; for(i=m+1,n=0;n k;i+)/* 找大于 m的素数,循环 k次,即找出紧靠 m的 k个素数*/ for(j=2; j i;j+)/*判断一个数是否为素数,如果不是,跳出此循环,判断下一个数*/ if (ij=0) break; if(j =i)/*如果是素数,放入数组 xx中*/ xxn+=i; )解析:解析:本题主要考查素数的判定方法,如果一个数不能被除了 1和其自身以外的数整除,则这个数为素数。本程序使用循环语句控制需要判断的数,在循环体中判断该数是否为素数,若是则存入数组 xx中。

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