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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】国家二级(C语言)机试-试卷36及答案解析.doc

1、国家二级(C 语言)机试-试卷 36 及答案解析(总分:12.00,做题时间:90 分钟)一、程序填空题(总题数:2,分数:4.00)1.程序填空题()(分数:2.00)_2.给定程序中,函数 fun 的功能是:求出形参 ss 所指字符串数组中最长字符串的长度,其余字符串左边用字符*补齐,使其与最长的字符串等长。字符串数组中共有 M 个字符串,且串长 #include #define M 5 #define N 20 void fun(char (*ss)N) int i, j, k=0, n, m, len; for(i=0; in) /*found*/ n=len; 【1】=i; for(

2、i=0; i=0; j-) ssim-=ssij; for(j=0; j_二、程序修改题(总题数:2,分数:4.00)3.程序修改题()(分数:2.00)_4.给定程序 MODllC 是建立一个带头结点的单向链表,并用随机函数为各结点数据域赋值。函数 fun 的作用是求出单向链表结点(不包括头结点)数据域中的最大值,并且作为函数值返回。 请改正函数 fun 中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! #include #include typedef struct aa int data; struct aa *next;

3、NODE; int fun (NODE *h) int max=-1; NODE *p; /*found*/ p=h; while(p) if(p-datamax) max=p-data; /*found*/ p-next; return max; outresult(int s, FILE *pf) fprintf(pf,“/nThe max in link : %d/n“,s); NODE *creatlink(int n, int m) NODE *h, *p, *s; int i; h=p=(NODE *)malloc(sizeof(NODE);h-data=9999; for(i=1

4、; idata=rand()%m; s-next=p-next; p-next=s; p=p-next; p-next=NULL; return h; outlink(NODE *h, FILE *pf) NODE *p; p=h-next; fprintf(pf,“/nTHE LIST :/n/n HEAD “); while(p) fprintf(pf,“-%d “,p-data); p=p-next; fprintf(pf,“/n“); main() NODE *head; int m; head=creatlink(12, 100); outlink(head , stdout); m

5、=fun(head); printf(“/nTHE RESULT :/n“); outresult(m, stdout); (分数:2.00)_三、程序设计题(总题数:2,分数:4.00)5.程序设计题()(分数:2.00)_6.程序定义了 NN 的二维数组,并在主函数中自动赋值。请编写函数 fun(int aN),函数的功能是:使数组左下三角元素中的值全部置成 0。 例如:a 数组中的值为 则返回主程序后 a 数组中的值应为 (分数:2.00)_国家二级(C 语言)机试-试卷 36 答案解析(总分:12.00,做题时间:90 分钟)一、程序填空题(总题数:2,分数:4.00)1.程序填空题(

6、)(分数:2.00)_解析:2.给定程序中,函数 fun 的功能是:求出形参 ss 所指字符串数组中最长字符串的长度,其余字符串左边用字符*补齐,使其与最长的字符串等长。字符串数组中共有 M 个字符串,且串长 #include #define M 5 #define N 20 void fun(char (*ss)N) int i, j, k=0, n, m, len; for(i=0; in) /*found*/ n=len; 【1】=i; for(i=0; i=0; j-) ssim-=ssij; for(j=0; j_正确答案:(正确答案: k len ssij)解析:解析:第一空:第一

7、 for 循环寻找最长的字符串,变量 n 记录字符串的长度,k 记录最长字符串的下标位置。i=0 时,将 n 赋值第一个字符串的长度,假设第一个字符串长度最长,以后其他字符串和 n 比较,如果比 n 大,则把新的字符串长度赋给 n,k 记录新的字符串下标位置,因此第一空处应为“k”。 第二空:“ssim-=ssij;”是将字符串 ssij的字符往后移动,腾出左边位置补“*”。字符串的长度为 len,字符串的最后一个字符 ssilen-1移动到 ssin-1,ssilen-2移动到 ssin-2,直到全部字符都往后移动 len 位,因此第二空处应为“len”。 第三空:此处的循环是把空处来的位置

8、补上“*”,因此第三空处应为“ssij”。二、程序修改题(总题数:2,分数:4.00)3.程序修改题()(分数:2.00)_解析:4.给定程序 MODllC 是建立一个带头结点的单向链表,并用随机函数为各结点数据域赋值。函数 fun 的作用是求出单向链表结点(不包括头结点)数据域中的最大值,并且作为函数值返回。 请改正函数 fun 中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! #include #include typedef struct aa int data; struct aa *next; NODE; int fun

9、 (NODE *h) int max=-1; NODE *p; /*found*/ p=h; while(p) if(p-datamax) max=p-data; /*found*/ p-next; return max; outresult(int s, FILE *pf) fprintf(pf,“/nThe max in link : %d/n“,s); NODE *creatlink(int n, int m) NODE *h, *p, *s; int i; h=p=(NODE *)malloc(sizeof(NODE);h-data=9999; for(i=1; idata=rand(

10、)%m; s-next=p-next; p-next=s; p=p-next; p-next=NULL; return h; outlink(NODE *h, FILE *pf) NODE *p; p=h-next; fprintf(pf,“/nTHE LIST :/n/n HEAD “); while(p) fprintf(pf,“-%d “,p-data); p=p-next; fprintf(pf,“/n“); main() NODE *head; int m; head=creatlink(12, 100); outlink(head , stdout); m=fun(head); p

11、rintf(“/nTHE RESULT :/n“); outresult(m, stdout); (分数:2.00)_正确答案:(正确答案:p=h-next; p=p- next;)解析:解析:(1)根据题干中求得除了头结点之外的结点数据域中的最大值,头指针 h,工作指针 p 指向头结点的下一个结点,所以第一个标识下的“p=h;”指向头结点应该改为指向下一个结点“p=h-next;”。 (2)工作指针 p,利用 p 实现对链表的遍历,p 表示指向链表的当前结点,所以指向下一个结点应该是“p=p- next;”。三、程序设计题(总题数:2,分数:4.00)5.程序设计题()(分数:2.00)_解

12、析:6.程序定义了 NN 的二维数组,并在主函数中自动赋值。请编写函数 fun(int aN),函数的功能是:使数组左下三角元素中的值全部置成 0。 例如:a 数组中的值为 则返回主程序后 a 数组中的值应为 (分数:2.00)_正确答案:(正确答案: int i, j; for(i=0; i=i; j+) aij=0; )解析:解析:进入 fun 函数,根据前面的分析: (1)对二维数组常用双重循环结构来处理:外层循环控制二维数组的行处理,内层循环控制二维数组的列处理。 (2)左下半三角元素的下标特点是列下标小于或等于行下标,即 j=i。 (3)依次访问二维数组,把符合以上条件的元素的值赋 0。 该题是对矩阵操作的考查。

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