【计算机类职业资格】二级C语言机试78及答案解析.doc
《【计算机类职业资格】二级C语言机试78及答案解析.doc》由会员分享,可在线阅读,更多相关《【计算机类职业资格】二级C语言机试78及答案解析.doc(3页珍藏版)》请在麦多课文档分享上搜索。
1、二级 C 语言机试 78 及答案解析(总分:100.00,做题时间:90 分钟)一、B填空题/B(总题数:1,分数:30.00)1.请补充函数 fun(),该函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排列,函数返回删除后数组中数据的个数。 例如,若一维数组中的数据是:1,1,1,2,2,2,3, 4,4,5,5,6,6,7,7,8,9,9,10,10。 删除后,数组中的内容应该是:1,2,3,4,5,6,7, 8,9,10。 注意:部分源程序给出如下。 请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun()的横线上填入所编写的若干表达式
2、或语句。 试题程序: #includestdio.h #define N 80 int fun(int a,int n) int i, t,j=0; t=a0; for(i=1;in;i+) if(U 【1】 /U) ; else U 【2】 /U; t=ai; aj+=t; return j; main() int aN=1,1,2,2,2,3,4,4,5,5,6,6,6, 7,7,8,9,9,10,10,i,n=20; printf(“The original data:/n“); for(i=0; in; i+) printf(“%4d“,ai); n=fun(a,n); printf(
3、“/n/nThe data after deleted ; /n“); for (i=0;in;i+) printf(“%4d“,ai); printf(“/n“); (分数:30.00)填空项 1:_二、B改错题/B(总题数:1,分数:30.00)2.下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点数据域赋值。函数 fun()的作用是求出单向链表结点(不包括头结点)数据域中的最大值,并且作为函数值返回。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构。 试题程序: #include stdio.h #includ
4、e conio.h #include stdlib.h typedef struct aa int data; struct aa *next; NODE; /*found*/ fun (NODE *h) int max=-1; NODE *p; p=h-next; while(p) if(p-datamax) max=p-data; /*found*/ p=h-next; return max; outresult(int s, FILE *pf) fprintf(pf, “/nThe max in link :%d/n “,s); NODE *creatlink(int n, int m)
5、 NODE *h,*p,*s,*q; int i, x; h=p=(NODE *)malloc(sizeof(NODE); h-data=9999; for(i=1;i=n;i+) s=(NODE *) malloc(sizeof(NODE); s-data=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, “/n The LIST :/n/n HEAD“); while(p) fprintf(p
6、f, “-%d“,p-data); p=p-next; fprintf(pf, “/n“); main ( ) NODE *head; int m; clrscr(); head=creatlink(12,100); outlink(head,stdout); m=fun(head); printf(“/nThe RESULT :/n“); outresult (m, stdout); (分数:30.00)填空项 1:_三、B编程题/B(总题数:1,分数:40.00)3.N 名学生的成绩已在主函数中放入一个带头节点的链表结构中,h 指向链表的头节点。请编写函数 fun(),它的功能是:找出学生
7、的最高分,由函数值返回。 注意:部分源程序给出如下。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。 试题程序: #include stdio.h #include stdlib.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(size
8、of(STREC); p-s=0; while(iN) /*产生 8 个节点的链表,各分数存入链表中*/ q=(STREC*) malloc(sizeof(STREC); p-s=si; i+; p-next=q; p=q; p-next=0; return h; /*返回链表的首地址* / outlist (STREC *h) STREC *p; p=h-next; printf(“head“); do printf(“-%2.0f “,p-s);p=p-next; /*输出各分数* / while (p!=0); printf(“/n/n “); main() double sN=85,7
9、6,69,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 语言机试 78 答案解析(总分:100.00,做题时间:90 分钟)一、B填空题/B(总题数:1,分数:30.00)1.请补充函数 fun(),该函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排列,函数返回删除后数组中数据的个数。 例如,若一维数组中的数据是:1,1,1,2,2,2,3, 4,4,5,5,6,6,7,7,8,9
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
5000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 职业资格 二级 语言 78 答案 解析 DOC
