[计算机类试卷]国家二级C语言机试(操作题)模拟试卷313及答案与解析.doc
《[计算机类试卷]国家二级C语言机试(操作题)模拟试卷313及答案与解析.doc》由会员分享,可在线阅读,更多相关《[计算机类试卷]国家二级C语言机试(操作题)模拟试卷313及答案与解析.doc(7页珍藏版)》请在麦多课文档分享上搜索。
1、国家二级 C语言机试(操作题)模拟试卷 313及答案与解析 一、程序填空题 1 给定程序中,函数 fun的功能是:将不带头结点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为 10,4、 2、 8、 6,排序后链表结点数据域从头至尾的数据为 2、 4、 6、 8、 10。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构 ! 试题程序: #include stdio h #include stdlib h #define N 6 typedef struct node int
2、data; struct node*next; NODE; void fun(NODE*h) NODE*p, *q; int t ; p=h; while(P) *found* q=【 1】 ; *found* while(【 2】 ) if(P data q data) t=P data; P data=q data ; q data=t; ) q=q next; *found* p=【 3】 ; NODE*creatlist(int a) NODE*h, *p, *q; int i; h=NULL; for(i=0; i N; i+) q=(NODE *)malloc(sizeof (NO
3、DE); q data=ai; q next=NULL; if(h=NULL)h=P=q; elseP next=q; P=q; ) return h; void outlist(NODE*h) NODE*P; p=h; if(P=NULL) printf(“The list is NULL! n“); else printf(“ nHead“); do printf(“ d“, P data); p=p next; ) while(p!=NULL); printf(“ End n“); main() NODE*head; int aN=0, 10, 4, 2, 8, 6); head=cre
4、atlist(a); printf(“ nThe original list: n“); outlist(head); fun(head); printf(“ nThe list after inverting: n“); outlist(head); 二、程序修改题 2 下列给定程序中函数 fun的功能是:求两个非零正整数的最大公约数,并作为函数值返回。 例如,若 num1和 num2分别为 49和 21,则输出的最大公约数为 7;若 num1和hum2分别为 27和 81,则输出的最大公约数为 27。 请改正程序中的错误,使它能得出正确结果。 注意:不要改动 main函数,不得增行或删行,
5、也不得更改程序的结构 ! 试题程序: #include stdio h int fun(int a, int b) int r, t; if(a b) *found* t=a; b=a; a; t; r=a b; while(r!=0) (a=b; b=r; r=a b; ) *found* return(a); void main() int hum1, hum2, a; printf ( “Input numl num2: “); scanf(“ d d“, &hum1, &hum2); printf(“num1= d hum2= d n n“, num1, num2); a=fun(nu
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
2000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 试卷 国家 二级 语言 操作 模拟 313 答案 解析 DOC
