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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、二级 C语言机试-271 及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.下列给定程序中,函数 fun的功能是:将 NN矩阵主对角线元素的值与反向对角线对应位置上元素的值进行交换。例如,若 N=3,有下列矩阵:1 2 34 5 67 8 9交换后为:3 2 14 5 69 8 7请在下划线处填入正确的内容并将下划线删除,使程序得出正确的结果。注意:部分源程序给出如下。不得增行或删行,也不得更改程序的结构!试题程序:#lncludestdio.h#define N 4/*found*/void fun(int (1) ,int n)inf

2、i,s;/*found*/for( (2) ;i+)(s=tii;tij=fin-i-1;/*found*/fin-i-1= (3) ;main()int tN=21,12,13,24,25,16,47,38,29,11,32,54,42,21,33,10,i,j;printf(“/nThe o riginal array:/n);for(i=0;iN;i+)(for(j=0;jN;j+)printf(“%d“tij);printf(“/n“);fun(t,N);printf(“/nThe result is:/n“);for(i=0;iN;i+)(for(j=0;jN;j+)printf(“

3、dtij);printf“/n“);(分数:30.00)_二、程序改错题(总题数:1,分数:30.00)2.由 N个有序整数组成的数列已放在一维数组中,下列给定程序中,函数 fun的功能是:利用折半查找法查找整数 m在数组中的位置。若找到,返回其下标值;否则,返回-1。折半查找的基本算法是:每次查找前先确定数组中待查的范围 low和 high(low(high),然后用 m与中间位置(mid)上元素的值进行比较。如果 m的值大于中间位置元素的值,则下一次的查找范围落在中间位置之后的元素中;反之,下一次的查找范围落在中间位置之前的元素中。直到 lowhjgh,查找结束。请改正程序中的错误,使它

4、能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdio.h#define N 10/*found*/void fun(int all,int m)int low=0,high=N-1,mid;while(low=high)mid=(low+high)/2;if(mamid)high=mid-1;/*found*/else If(mamid)low=mid+1;else return(mid);return(-1);main()int i,aN=(-3,4,7,9,13,45,67,89,100,180,k,m;printf(“

5、a数组中的数据如下:“);for(i=0;iN;i+)printf(“%d“,ai);printf(“Enter m:“);scanf(“%d“,k=fun(a,m);if(k=0)printf(“m=%d,index=%d/n“,m,k);else printf(“Not be found!/n“);(分数:30.00)_三、程序设计题(总题数:1,分数:40.00)3.假定输入的字符串中只包含字母和*号。请编写函数 fun,其功能是:除了尾部的*号之外,将字符中其他的*号全部删除。形参 P已指向字符串中最后的一个字母。在编写函数时,不得使用 C语言提供的字符串函数。例如,字符串中的内容为“

6、A*B*DEF*G*”,删除后,字符串中的内容应当是“ABCDEFG*”。注意:部分源程序给出如下。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若干语句。试题程序:#incIudeconio.h#includesfdio.hvoid fun(char*a,char*P)void main()char s81,*t;printf(“Enter a string:/n“);gets(s);t=s;while(*t)t+;t-;/*指针 t指向字符串尾部*/while(*t=*)t-;/*指针 t指向最后一个字母*/fun(s,t);printf(“The

7、 string after deleted:/n“);puts(s);(分数:40.00)_二级 C语言机试-271 答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.下列给定程序中,函数 fun的功能是:将 NN矩阵主对角线元素的值与反向对角线对应位置上元素的值进行交换。例如,若 N=3,有下列矩阵:1 2 34 5 67 8 9交换后为:3 2 14 5 69 8 7请在下划线处填入正确的内容并将下划线删除,使程序得出正确的结果。注意:部分源程序给出如下。不得增行或删行,也不得更改程序的结构!试题程序:#lncludestdio.h#de

8、fine N 4/*found*/void fun(int (1) ,int n)inf i,s;/*found*/for( (2) ;i+)(s=tii;tij=fin-i-1;/*found*/fin-i-1= (3) ;main()int tN=21,12,13,24,25,16,47,38,29,11,32,54,42,21,33,10,i,j;printf(“/nThe o riginal array:/n);for(i=0;iN;i+)(for(j=0;jN;j+)printf(“%d“tij);printf(“/n“);fun(t,N);printf(“/nThe result

9、is:/n“);for(i=0;iN;i+)(for(j=0;jN;j+)printf(“%dtij);printf“/n“);(分数:30.00)_正确答案:(tN (2)i=0;jN (3)s)解析:解析 本题关键字有:函数定义;for 循环语句;数组操作;变量值的交换算法。微分析填空 1:main 函数中的 fun函数调用语句的第一个参数为二维数组,所以应填入 tN。填空 2:由于是 NN矩阵,所以变量 i的取值范围是 0N。填空 3:反向对角线上元素应存放对应主对角线上元素的值,所以填入 s。二、程序改错题(总题数:1,分数:30.00)2.由 N个有序整数组成的数列已放在一维数组中,

10、下列给定程序中,函数 fun的功能是:利用折半查找法查找整数 m在数组中的位置。若找到,返回其下标值;否则,返回-1。折半查找的基本算法是:每次查找前先确定数组中待查的范围 low和 high(low(high),然后用 m与中间位置(mid)上元素的值进行比较。如果 m的值大于中间位置元素的值,则下一次的查找范围落在中间位置之后的元素中;反之,下一次的查找范围落在中间位置之前的元素中。直到 lowhjgh,查找结束。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!试题程序:#includestdio.h#define N 10/*

11、found*/void fun(int all,int m)int low=0,high=N-1,mid;while(low=high)mid=(low+high)/2;if(mamid)high=mid-1;/*found*/else If(mamid)low=mid+1;else return(mid);return(-1);main()int i,aN=(-3,4,7,9,13,45,67,89,100,180,k,m;printf(“a数组中的数据如下:“);for(i=0;iN;i+)printf(“%d“,ai);printf(“Enter m:“);scanf(“%d“,k=fu

12、n(a,m);if(k=0)printf(“m=%d,index=%d/n“,m,k);else printf(“Not be found!/n“);(分数:30.00)_正确答案:(int fun(int a,int m)或 fun(int a,int m)(2)else if(mamid)解析:解析 本题关键字有:函数定义;ifelse 语句;折半查找算法。折半查找算法以有序数列的中间位置元素为比较对象,若查找的元素值小于该中间元素,则在左半部分继续查找,若查找的元素大于中间元素,则在右半部分继续查找,比较一次查找范围缩小一半。微分析(1)fun函数的返回值为 int类型,所以返回类型不能

13、是 void,而是 inc类型。这里 inc可以省略,函数类型标识符省略则默认为 int型。(2)C语言区分大小写,大写 If应改为小写。三、程序设计题(总题数:1,分数:40.00)3.假定输入的字符串中只包含字母和*号。请编写函数 fun,其功能是:除了尾部的*号之外,将字符中其他的*号全部删除。形参 P已指向字符串中最后的一个字母。在编写函数时,不得使用 C语言提供的字符串函数。例如,字符串中的内容为“*A*B*DEF*G*”,删除后,字符串中的内容应当是“ABCDEFG*”。注意:部分源程序给出如下。请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的

14、若干语句。试题程序:#incIudeconio.h#includesfdio.hvoid fun(char*a,char*P)void main()char s81,*t;printf(“Enter a string:/n“);gets(s);t=s;while(*t)t+;t-;/*指针 t指向字符串尾部*/while(*t=*)t-;/*指针 t指向最后一个字母*/fun(s,t);printf(“The string after deleted:/n“);puts(s);(分数:40.00)_正确答案:(void fun(char*a,char*p)char*t=a;for(;t=p;t+)if(*t!*)*(a+)=*f;/*保留 p以前所有不是*号的字符*/for(;*t!=/0;t+)*(a+)=*t/*保留 D以后的所有*号*/*a=/0; /*在字符串最后加上字符串结束标识符*/)解析:解析 本题关键字有:字符串操作;指针变量。微分析通过两个循环来完成操作。第 1个循环将指针 p所指字母以前所有非*号的字符保留下来,第 2个循环将指针 D以后的所有*号进行保存,并在新串的结尾加上结束符。

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