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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】二级C语言-343及答案解析.doc

1、二级 C 语言-343 及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.函数 fun 的功能是:统计所有小于等于 n(n2)的素数的个数,素数的个数作为函数值返回。 请在程序的下划线处填人正确的内容并把下划线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构! 试题程序: #indudestdio.h int fun(int n) (int i, j, count=0; printf(“nThe prime number between 3 to %d/n“, n); for(i=3; i=n;

2、 i+) /*found*/ for 1; ji; j+) /*found*/ if( 2%j=0) break; /*found*/ if( 3=i) count+; printf(count%15?“%5d“:“/n%5d“, i); return count main() (int n=20, r; r=fun(n); printf(“/nThe number of prime is:%d/n“, r); (分数:30.00)二、程序改错题(总题数:1,分数:30.00)2.数列中,第一项为 3,后一项都比前一项的值增 5。下列给定程序中,函数 fun 的功能是:计算前n(4n50)项的

3、累计和。在累加过程中把那些被 4 除后余 2 的当前累加值放入数组中,符合此条件的累加值的个数作为函数值返回。 例如,当 n 的值为 20 时,该数列为 3、8、13、18、23、28、93、98,符合此条件的累加值应为42、126、366、570、1010。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 试题程序: #includestdio.h #define N 20 int fun(int n, int *a) /*found*/ int i, j, k, sum; sum=0; for(k=3, i=0; in;

4、i+, k+=5) sum=sum+k; /*found*/ if(sum%4=2) aj+=sum; /*found*/ return j; void main() int aN, d, n, i; printf(“/nEnter n(4=n=50):“); scanf(“%d“, d=fun(n, a); printf(“/n/nThe result:/n“); for(i=0; id; i+) printf(“%6d“, ai); printf(“/n/n“); (分数:30.00)三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,其功能是:计算并输出下列多项式的值。

5、 S=(1-1/2)+(1/3-1/4)+(1/(2n-1)-1/2n) 例如,若主函数从键盘给 n 输入 8 后,则输出为 S=0.662872。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入你编写的若干语句。 试题程序: #includestdio.h double fun(int n) void main() int n; double s; printf(“/nlnput n:“); scanf(“%d“, s=fun(n); printf(“/nS=%f/n“, s); (分数:40.00)_二级 C 语言-343 答

6、案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.函数 fun 的功能是:统计所有小于等于 n(n2)的素数的个数,素数的个数作为函数值返回。 请在程序的下划线处填人正确的内容并把下划线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构! 试题程序: #indudestdio.h int fun(int n) (int i, j, count=0; printf(“nThe prime number between 3 to %d/n“, n); for(i=3; i=n; i+) /*found*/

7、 for 1; ji; j+) /*found*/ if( 2%j=0) break; /*found*/ if( 3=i) count+; printf(count%15?“%5d“:“/n%5d“, i); return count main() (int n=20, r; r=fun(n); printf(“/nThe number of prime is:%d/n“, r); (分数:30.00)解析:(1)j=2 (2)i (3)j 解析 填空 1:j 的初始化要从 2 开始,因为要判断一个数是否为素数即将其除以从 2 开始的数字,看有没有被整除的。 填空 2:如果碰到有个数字 j

8、可以被 i 整除,那么表示这个数不是素数,要用 break 直接结束循环,这个时候的 j 肯定小于 i。 填空 3:j=i,表示在上面 if(i%j=0)没有成功,所以会循环执行 for(j=2; ji; j+),以致最后j=i,这样可以知道该数字 i 就是素数。二、程序改错题(总题数:1,分数:30.00)2.数列中,第一项为 3,后一项都比前一项的值增 5。下列给定程序中,函数 fun 的功能是:计算前n(4n50)项的累计和。在累加过程中把那些被 4 除后余 2 的当前累加值放入数组中,符合此条件的累加值的个数作为函数值返回。 例如,当 n 的值为 20 时,该数列为 3、8、13、18

9、、23、28、93、98,符合此条件的累加值应为42、126、366、570、1010。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 试题程序: #includestdio.h #define N 20 int fun(int n, int *a) /*found*/ int i, j, k, sum; sum=0; for(k=3, i=0; in; i+, k+=5) sum=sum+k; /*found*/ if(sum%4=2) aj+=sum; /*found*/ return j; void main() in

10、t aN, d, n, i; printf(“/nEnter n(4=n=50):“); scanf(“%d“, d=fun(n, a); printf(“/n/nThe result:/n“); for(i=0; id; i+) printf(“%6d“, ai); printf(“/n/n“); (分数:30.00)解析:(1)int i, j=0, k, sum; (2)if(sum%4=2) 解析 (1)变量 j 用于控制数组下标,使用前应初始化为 0。 (2)这里混淆了“=”与“=”的区别,“=”是比较运算符,“=”是赋值运算符。三、程序设计题(总题数:1,分数:40.00)3.请编

11、写函数 fun,其功能是:计算并输出下列多项式的值。 S=(1-1/2)+(1/3-1/4)+(1/(2n-1)-1/2n) 例如,若主函数从键盘给 n 输入 8 后,则输出为 S=0.662872。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入你编写的若干语句。 试题程序: #includestdio.h double fun(int n) void main() int n; double s; printf(“/nlnput n:“); scanf(“%d“, s=fun(n); printf(“/nS=%f/n“, s); (分数:40.00)_正确答案:()解析:double fun(int n) int i; double s=0.0; for(i=1; i=n; i+) s=s+(1.0/(2*i-1)-1.0/(2*i); /*计算 S=(1-1/2)+(1/3-1/4)+(1/(2n-1)-1/2n)*/ return s; 解析 对于求多项式值的题目,一般都使用循环语句来累加计算多项式的通项。本题中多项式的通项为 1/(2n-1)-1/2n,循环变量的取值范围为 1n。注意,存放累加和的变量 s 要定义为实型,累加时要进行类型转换。

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