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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、二级 C 语言机试-212 及答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)请补充 main 函数,该函数的功能是:从键盘输入一个长整数,如果这个数是负数,则取它的绝对值,并显示出来。例如:输入-12345678,结果为 12345678。注意:部分源程序已给出。请勿改动函数中的其他任何内容,仅在横线上填入所编写的若干表达式或语句。试题程序:#includestdio.h#includeconio.hvoid main()long int n;printf(“Enter the data:/n“);seanf( (1) );printf(“*th

2、e origial data*/n“);if(n0)(2) printf(“/n/n“);printf( (3) );(分数:30.00)填空项 1:_填空项 1:_填空项 1:_二、改错题(总题数:1,分数:30.00)1.下列给定程序中函数 fun 的功能是:把从主函数中输入的 3 个数,最大的数放在 a 中,中间的数放在 b中,最小的数放在 C 中。例如,若输入的数为:55 12 34,输出的结果应当是a=55.0,b=34.0,c=12.0。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdi

3、o.hvoid fun(float*a,float*b,float*c)/*found*/float*k;if(*a*b)k=*a:*a=*b:*b=k;/*found*/if(*a*c)k=*c:*c=*a:*a=k;if(*b*c)k=*b;*b=*c;*c=k;void main()float a,b,c;printf(“Input a b c:“);scanf(“%f%f%f“,&a,&b,&c);printf(“a=%4.1f,b=%4.1f,c=%4.1f/n/n“,a,b,c);fun(&a,&b,&c);printf(“a=%4.1f,b=%4.1f,c=%4.1f/n/n“,

4、a,b,c);(分数:30.00)填空项 1:_三、编程题(总题数:1,分数:40.00)2.N 名学生的成绩已在主函数中放入一个带有头结点的链表结构中,h 指向链表的头结点。请编写函数fun,其功能是:找出学生的最高分,并由函数值返回。注意:部分源程序已给出。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。试题程序:#includestdio.h#includestdlib.h#define N 8struet slistdouble s;struct slist*next;typedef struct slist STREC;double

5、 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)/*产生 8 个结点的链表,各分数存入链表中*/q=(STREC*)malloc(sizeof(STREC);p-s=si;i+;p-next=q;p=q;p-next=NULL;return h;/*返回链表的首地址*/void outlist(STREC*h)STREC *p;p=h;printf(“head“);doprintf(“-%2.0f“,p-s);p=p-next;/*输出

6、各分数*/while(p-next!=NULL);printf(“/n/n“);void main()double sN=85,100,99,85,91,72,64,87,max;STREC*h;h=creat(s);outlist(h);max=fun(h);printf(“max=%6.1f/n“,max);(分数:40.00)_二级 C 语言机试-212 答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)请补充 main 函数,该函数的功能是:从键盘输入一个长整数,如果这个数是负数,则取它的绝对值,并显示出来。例如:输入-12345678,结果

7、为 12345678。注意:部分源程序已给出。请勿改动函数中的其他任何内容,仅在横线上填入所编写的若干表达式或语句。试题程序:#includestdio.h#includeconio.hvoid main()long int n;printf(“Enter the data:/n“);seanf( (1) );printf(“*the origial data*/n“);if(n0)(2) printf(“/n/n“);printf( (3) );(分数:30.00)填空项 1:_ (正确答案:“%1d“,&n)解析:填空项 1:_ (正确答案:n=-n;或 n*=-1)解析:填空项 1:_

8、正确答案:“%1d“,n)解析:解析 此题考查基本的输入输出函数 scanf 和 printf 的使用。用户从键盘输入一个长整数将此赋值给变量 n,如果这个数是负数,则将其取反(即取它的绝对值),并显示出来。本题的关键是使用函数scanf、printf 通过参数,格式化输入输出。二、改错题(总题数:1,分数:30.00)1.下列给定程序中函数 fun 的功能是:把从主函数中输入的 3 个数,最大的数放在 a 中,中间的数放在 b中,最小的数放在 C 中。例如,若输入的数为:55 12 34,输出的结果应当是a=55.0,b=34.0,c=12.0。请改正程序中的错误,使它能得出正确的结果。注

9、意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdio.hvoid fun(float*a,float*b,float*c)/*found*/float*k;if(*a*b)k=*a:*a=*b:*b=k;/*found*/if(*a*c)k=*c:*c=*a:*a=k;if(*b*c)k=*b;*b=*c;*c=k;void main()float a,b,c;printf(“Input a b c:“);scanf(“%f%f%f“,&a,&b,&c);printf(“a=%4.1f,b=%4.1f,c=%4.1f/n/n“,a,b,c);

10、fun(&a,&b,&c);printf(“a=%4.1f,b=%4.1f,c=%4.1f/n/n“,a,b,c);(分数:30.00)填空项 1:_ (正确答案:(1)错误:float*k;正确:float k;(2)错误:if(*a*c)正确:if(*a*c))解析:解析 变量定义首先要判断变量的类型,给定程序的赋值语句中,k 是以变量形式进行赋值的,所以 k 不是指针,定义为指针是不正确的;由给出程序可以看出,if 语句是为了将小于*c 的值放入*c 中,所以应该改为 if(*a*c)。三、编程题(总题数:1,分数:40.00)2.N 名学生的成绩已在主函数中放入一个带有头结点的链表结构

11、中,h 指向链表的头结点。请编写函数fun,其功能是:找出学生的最高分,并由函数值返回。注意:部分源程序已给出。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。试题程序:#includestdio.h#includestdlib.h#define N 8struet slistdouble 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(

12、sizeof(STREC);p-s=0;while(iN)/*产生 8 个结点的链表,各分数存入链表中*/q=(STREC*)malloc(sizeof(STREC);p-s=si;i+;p-next=q;p=q;p-next=NULL;return h;/*返回链表的首地址*/void outlist(STREC*h)STREC *p;p=h;printf(“head“);doprintf(“-%2.0f“,p-s);p=p-next;/*输出各分数*/while(p-next!=NULL);printf(“/n/n“);void main()double sN=85,100,99,85,9

13、1,72,64,87,max;STREC*h;h=creat(s);outlist(h);max=fun(h);printf(“max=%6.1f/n“,max);(分数:40.00)_正确答案:(double fun(STREC*h)double max=h-s;while(h!=NULL)/*通过循环找到最高分数*/if(maxh-s)max=h-s;h=h-next;return max;)解析:解析 本题考查的是结构体类型、指针型变量、链表和 if 语句等知识点。需要用 for 循环遍历链表中的每一个结点,用判断语句比较结点数据域的大小。可以通过 while 循环实现对最大成绩的查找,具体步骤为遍历链表,遇到比 max 大的值(maxh-s)则赋值给 max,max=h-s。需要注意的是,h 是指向结构体类型的指针变量,引用它指向的结构体的成员时,要用指向运算符“-”。

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