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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、二级 C 语言机试 60 及答案解析(总分:100.00,做题时间:90 分钟)一、B填空题/B(总题数:1,分数:30.00)1.请补充 main 函数,该函数的功能是:输出一个 33 的矩阵,要求必须使用行指针表示输出变量。 注意;部分源程序给出如下 请勿改动主函数 main 和其他函数中的任何内容,仅在 main 函数的横线上填入所编写的若干表达式或语句。 试题程序: #includes tdio. h main() static int array3 3=9,8,7, 6,5, 4, (3,2,1; iht (*p) 3,j,i; p=U【1】/U clrscr (); for (i=

2、0; i3; i+) printf (“ /n/n“ ); for (j=0; j3; j+) printf(“%4d“,U 【2】/U ); (分数:30.00)填空项 1:_二、B改错题/B(总题数:1,分数:30.00)2.下列给定程序中,函数 fun()的功能是:计算整数 n 的阶乘。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include stdio.h double fun(int n) double result=l.0; whil (nl /*found*/ return; main()

3、int. n; clrscr(); printf(“Enter an integer: “); scanf(“%d“, printf(“/n/n%d!=%lg/n/n “,n, fun(n); (分数:30.00)填空项 1:_三、B编程题/B(总题数:1,分数:40.00)3.N 名学生的成绩己在主函数中放入一个带头节点的链表结构中,h 指向链表的头节点。请编写函数 fun(),它的功能是:求出平均分,由函数值返回。 例如,若学生的成绩是 85,76,69,91,72,64,87,则平均分应当是 78.625。 注童:部分源程序给出如下 请勿改动主函数 main 和其他函数中的任何内容,仅在

4、函数 6m 的花括号中填入所编写的若干语句。 试题程序: #includestdlib.h #includestdio. h #define N 8 struct slist double s; struct slist *next; ; typedef struct slist STREC; double fun(STREC *h) STREC *creat(double *s) /*创建链表*/ STREC *h,*p, *q; int i=0; h=p= ( STREC*)malloc (sizeof (STREC); p-s=0; while (iN) q= ( STREC*)mall

5、oc (sizeof (STREC); q-s=s Ii; i+;p-next=q;p=q; p-next=0; return h; outlist (STREC *h) STREC *p; p=h-next; printf (“head “); do printf (“-%4. if “,p-s); p=p-next; /*输出各成绩*/ while (p !=0) main () double s N = 85,76, 69, 85, 91,72, 64, 87,ave; STREC *h; h=creat (s); outlist (h); ave=fun (h); printf (“a

6、ve=%6.3f/n “, ave); (分数:40.00)_二级 C 语言机试 60 答案解析(总分:100.00,做题时间:90 分钟)一、B填空题/B(总题数:1,分数:30.00)1.请补充 main 函数,该函数的功能是:输出一个 33 的矩阵,要求必须使用行指针表示输出变量。 注意;部分源程序给出如下 请勿改动主函数 main 和其他函数中的任何内容,仅在 main 函数的横线上填入所编写的若干表达式或语句。 试题程序: #includes tdio. h main() static int array3 3=9,8,7, 6,5, 4, (3,2,1; iht (*p) 3,j,

7、i; p=U【1】/U clrscr (); for (i=0; i3; i+) printf (“ /n/n“ ); for (j=0; j3; j+) printf(“%4d“,U 【2】/U ); (分数:30.00)填空项 1:_ (正确答案:1array 2*(*(p+i)+j))解析:解析 填空 1:p 是一个指针,指向大小为 3 的一维数组。首先要使指针 p 指向数组 array 的首地址,而数组名 array 即表示数组 slray 的首地址,所以将 array 赋给 p。填空 2:*(*(p+i+j)表示数组的第 i 行第 j 列元素,即 arrayij。二、B改错题/B(总

8、题数:1,分数:30.00)2.下列给定程序中,函数 fun()的功能是:计算整数 n 的阶乘。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include stdio.h double fun(int n) double result=l.0; whil (nl /*found*/ return; main() int. n; clrscr(); printf(“Enter an integer: “); scanf(“%d“, printf(“/n/n%d!=%lg/n/n “,n, fun(n); (分

9、数:30.00)填空项 1:_ (正确答案:(1)错误:result*=-n; 正确:result*=n-;)解析:(2)错误:return; 正确:return result; 解析 该题采用循环语句计算 n 的阶乘。当 n 大于1 且小于 170 时,令 result 与 n 相乘,同时 n 自动减 1,循环至 n=2(n=1 时无需相乘):注意:o 和 1 的阶乘都等于 1,可用条件语句和循环语句实现上述功能。三、B编程题/B(总题数:1,分数:40.00)3.N 名学生的成绩己在主函数中放入一个带头节点的链表结构中,h 指向链表的头节点。请编写函数 fun(),它的功能是:求出平均分,

10、由函数值返回。 例如,若学生的成绩是 85,76,69,91,72,64,87,则平均分应当是 78.625。 注童:部分源程序给出如下 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 6m 的花括号中填入所编写的若干语句。 试题程序: #includestdlib.h #includestdio. h #define N 8 struct slist double s; struct slist *next; ; typedef struct slist STREC; double fun(STREC *h) STREC *creat(double *s) /*创建链表*/ ST

11、REC *h,*p, *q; int i=0; h=p= ( STREC*)malloc (sizeof (STREC); p-s=0; while (iN) q= ( STREC*)malloc (sizeof (STREC); q-s=s Ii; i+;p-next=q;p=q; p-next=0; return h; outlist (STREC *h) STREC *p; p=h-next; printf (“head “); do printf (“-%4. if “,p-s); p=p-next; /*输出各成绩*/ while (p !=0) main () double s N

12、 = 85,76, 69, 85, 91,72, 64, 87,ave; STREC *h; h=creat (s); outlist (h); ave=fun (h); printf (“ave=%6.3f/n “, ave); (分数:40.00)_正确答案:()解析:double fun(STREC *h) double av=0.0; STREC *p-h-next; /*p 直接指向“头结点”的下一个结点,即第个成绩*/ while(p!=NULL) aY=ay+p-s; /*求总分数*/ p=p-next; return ay/N; /*返回平均值*/ 解析 本题是关于链表问题,所以,一定要弄清表示出使指针变量 p 指向下一个“结点”的方法及表示结束的判断,本题中,因为“头结点”中没有数值,所以程序中让 p 直接指向“头结点”的下一个结点,使用语句 STREC*p=h-next,当然也可将 p 一开始就指向“头结点”。

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