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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、二级 C 语言机试-285 及答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)1.请补充函数 fun(),该函数的功能是;交换数组 aa 中最大和最小两个元素的位置,结果依然保存在原数组中,其它元素位置不变。注意数组 aa 中没有相同元素。例如,输入“33,67,42,58,25,76,85,16,41, 56”,则输出“33,67,42,58,25,76,16,85,41,56”。注意;部分源程序给出如下。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun()的横线上填入所编写的若干表达式或语句。试题程序:#include std

2、io. h#define N 10void fun(int aa)int i, j, t;int max=0, min=0;for(i=0; iN; i+)if( 【1】 )max=i;if( 【2】 )min=i;t=aa max;【3】 ;aa min =t;main()int i;int aa N =33, 67, 42,58,25, 76, 85,16, 41, 56;clrscr ();printf(“/n* original list */n“);for(i=0; iN; i+)printf (“%4d“, aa i );fun (aa);printf (“/n* new list

3、 */n“);for(i=0; iN; i+)printf (“%4d“, aa i);(分数:30.00)填空项 1:_二、改错题(总题数:1,分数:30.00)2.N 个有序整数数列已放在一维数组中,给定下列程序中,函数 fun()的功能是:利用折半查找算法查找整数 m 在数组中的位置。若找到,则返回其下标值:反之,则返回-1。折半查找的基本算法是:每次查找前先确定数组中待查的范围:low 和 high(lowhigh),然后把 m 与中间位置(mid)中元素的值进行比较。如果 m 的值大于中间位置元素中的值,则下一次的查找范围放在中间位置之后的元素中;反之,下次查找范围落在中间位置之前的

4、元素中。直到 lowhigh,查找结束。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。试题程序:#include stdio.h#define N 10/*found*/void fun(int a,int m)int low-0,high=N-l,mid;while (low=high)mid=(low+high)/2;if(mamid)high=mid-1;/*found*/else if(m=a mid)low=mid+1;else return(mid);return(-1);main ()int i,aN=-3,4,7

5、,9,13,24,67,89,100,180,k,m;printf (“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(),该函数的功能是:移动一维数组中的内容,若数组中有 n 个整数,要求把下标从 0到 p(pn-1)的数组元

6、素平移到数组的最后。例如,一维数组中的原始内容为 1,2,3,4,5,6,7, 8,9,10,11,12,13,14,15,p 的值为 3。移动后,一维数组中的内容应为 5,6,7,8,9,10,11,12,13,14,15, 1, 2, 3, 4。注意:部分源程序给出如下。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。试题程序:#include stdio.h#define N 80void fun(int *w, int p, int n)main ()int aN=1,2,3,4,5,6,7,8,9,10,11,12,13,14,15

7、;int i, p, n=15;printf(“The original data:/n“);for(i=0;in;i+)printf(“%3d“,ai);printf(“/n/nEnter p: “);scanf(“%d“,fun(a,p,n);printf(“/nThe data after moving:/n“);for(i=0;in;i+)printf(“%3d“,ai);printf(“/n/n“);(分数:40.00)_二级 C 语言机试-285 答案解析(总分:100.00,做题时间:90 分钟)一、填空题(总题数:1,分数:30.00)1.请补充函数 fun(),该函数的功能是

8、;交换数组 aa 中最大和最小两个元素的位置,结果依然保存在原数组中,其它元素位置不变。注意数组 aa 中没有相同元素。例如,输入“33,67,42,58,25,76,85,16,41, 56”,则输出“33,67,42,58,25,76,16,85,41,56”。注意;部分源程序给出如下。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun()的横线上填入所编写的若干表达式或语句。试题程序:#include stdio. h#define N 10void fun(int aa)int i, j, t;int max=0, min=0;for(i=0; iN; i+)if( 【

9、1】 )max=i;if( 【2】 )min=i;t=aa max;【3】 ;aa min =t;main()int i;int aa N =33, 67, 42,58,25, 76, 85,16, 41, 56;clrscr ();printf(“/n* original list */n“);for(i=0; iN; i+)printf (“%4d“, aa i );fun (aa);printf (“/n* new list */n“);for(i=0; iN; i+)printf (“%4d“, aa i);(分数:30.00)填空项 1:_ (正确答案:1 aamaxaai 2aam

10、inaai 3aamax=aamin)解析:解析 填空 1:先假设 aa0最大,如果找到更大的元素,则将这个元素的下标赋给 max。填空2:同理,先假设 aa0最小,如果找到更小的元素,则将这个元素的下标赋给 min。填空 3:找到最大值和最小值之后,借助第三个变量 t 交换这两个元素。二、改错题(总题数:1,分数:30.00)2.N 个有序整数数列已放在一维数组中,给定下列程序中,函数 fun()的功能是:利用折半查找算法查找整数 m 在数组中的位置。若找到,则返回其下标值:反之,则返回-1。折半查找的基本算法是:每次查找前先确定数组中待查的范围:low 和 high(lowhigh),然后

11、把 m 与中间位置(mid)中元素的值进行比较。如果 m 的值大于中间位置元素中的值,则下一次的查找范围放在中间位置之后的元素中;反之,下次查找范围落在中间位置之前的元素中。直到 lowhigh,查找结束。请改正程序中的错误,使它能得出正确的结果。注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。试题程序:#include stdio.h#define N 10/*found*/void fun(int a,int m)int low-0,high=N-l,mid;while (low=high)mid=(low+high)/2;if(mamid)high=mid-1;/*

12、found*/else if(m=a mid)low=mid+1;else return(mid);return(-1);main ()int i,aN=-3,4,7,9,13,24,67,89,100,180,k,m;printf (“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)_正确答案

13、:(1)错误:void fun(int a,int m) 正确:int fun(int a,int m)(2)错误:else if(m=amid) 正确:else if(mamid)解析:解析 fun (int a,int m)函数的返回值为 int 类型,所以定义函数时,函数的返回类型不能是void,而是 int 类型。else if(m=amid中的 mamid与 m=amid两个条件段的结果不一样,所以要分开考虑。三、编程题(总题数:1,分数:40.00)3.请编写函数 fun(),该函数的功能是:移动一维数组中的内容,若数组中有 n 个整数,要求把下标从 0到 p(pn-1)的数组元素

14、平移到数组的最后。例如,一维数组中的原始内容为 1,2,3,4,5,6,7, 8,9,10,11,12,13,14,15,p 的值为 3。移动后,一维数组中的内容应为 5,6,7,8,9,10,11,12,13,14,15, 1, 2, 3, 4。注意:部分源程序给出如下。请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。试题程序:#include stdio.h#define N 80void fun(int *w, int p, int n)main ()int aN=1,2,3,4,5,6,7,8,9,10,11,12,13,14,15;

15、int i, p, n=15;printf(“The original data:/n“);for(i=0;in;i+)printf(“%3d“,ai);printf(“/n/nEnter p: “);scanf(“%d“,fun(a,p,n);printf(“/nThe data after moving:/n“);for(i=0;in;i+)printf(“%3d“,ai);printf(“/n/n“);(分数:40.00)_正确答案:(void fun(int *w,int p,int n)int i, j, t;for(i=0; i=p; i+) /*循环左移 p+1 次*/t=w0;for(j=1/jn;j+) /*实现循环左移*/wj-1=wj;wj-1=t;)解析:解析 本题采用“循环左移”的算法(关于“循环左移”,我们在后面的试题中有详细的解释)。和我们在前面分析的稍有不同的是,一个是整型数组,一个是字符型数组。

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