首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序中,函数fun的功能是将带头节点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为:10、4、2、8、6,排序后链表结点数据域从头至尾的数据为:2、4、6、8、10。 请在程序的下划线处填入正确的内容并把下划线删除,使程
给定程序中,函数fun的功能是将带头节点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为:10、4、2、8、6,排序后链表结点数据域从头至尾的数据为:2、4、6、8、10。 请在程序的下划线处填入正确的内容并把下划线删除,使程
admin
2019-09-02
28
问题
给定程序中,函数fun的功能是将带头节点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为:10、4、2、8、6,排序后链表结点数据域从头至尾的数据为:2、4、6、8、10。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
#include <stdio.h>
#include <stdlib.h>
#define N 6
typedef struct node{
int data;
struct riode *next;
}NODE;
void fun(NODE*h)
{NODE*p,*q;int t;
/**********found**********/
p=___1___;
while(p){
/**********found**********/
q=___2___;
while(q){
/**********found**********/
if(p->data___3___q->data)
{t=p->data;p->data=q->data;q->data=t;}
q=q->next;
}
p=p->next;
}
}
NODE*creatlist(int a[])
{NODE*h,*p,*q;int i;
h=(NODE*)malloc(sizeof(NODE));
h->next=NULL;
for(i=0;i<N;i++)
{q=(NODE*)malloc(sizeof(NODE));
q->data=a
;
q->next=NULL;
if(h->next==NULL)h->next=p=q;
else {p->next=q;p=q;}
}
return h;
}
void outlist(NODE*h)
{NODE*p;
p=h->next;
if(p==NULL)printf("The list isNULL!\n");
else
{printf("\nHead");
do
{printf("->%d",p->data);p=p->next;}
while(p!=NULL);
printf("->End\n");
}
}
main()
{NODE*head;
int a[N]={0,10,4,2,8,6};
head=creatlist(a);
printf("\nThe original list:\n");
outlist(head);
fun(head);
printf("\nThe list after sorting:\n");
outlist(head);
}
选项
答案
(1)h->next (2)p->next (3)>=
解析
函数fun的功能是将带头节点的单向链表结点数据域中的数据从小到大排序,在fun函数内采用的是选择法排序。
第一空:由审题分析可知,q从h的下一个元素开始寻找最小值,故第一空为“h->next”。
第二空:由审题分析可知,while循环是在剩下的元素当中找最小值,剩下的结点是由q指向的链表,q从p的后一个结点开始,故第二空处应为“p->next”。
第三空:“if(p->data[3]q->data)”是比较p结点和q结点数据的大小,如果p结点的数据比q结点的数据大,那么应该将p结点和q结点的数据进行交换,故第三空处应为“>=”。
转载请注明原文地址:https://kaotiyun.com/show/RORp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
给定程序MODI1.C中函数fun的功能是:应用递归算法求形参a的平方根。求平方根的迭代公式如下:例如,a为2时,平方根值为:1.414214。请改正程序中的错误,使它能得出正确结果。注意:不要改动main函数,不得增行或删
下列选项中不属于结构化程序设计方法的是
有下列程序:voidf(int*q){inti=0;for(;i<5;i++)(*q)++;}main(){inta[5]={1,2,3,4,5},i;f(a);for(i=0;i
若有以下程序,编译时出现错误,你认为出错的是#includemain(){inta=0,b=0,c=0,d;c=(a+=b,,b+=A)/*第4行*/d=c;;/*第5行*/;/*第6行*/printf("%d,%d,%d\n",a,b
以下叙述中正确的是
若以下选项中的变量a,b,y均已正确定义并赋值,则语法正确的switch语句是
有两个关系R和S如下: 则由关系R得到关系S的操作是
有三个关系R、S和T如下: 则由关系R和S得到关系T的操作是
当用户要求输入的字符串中含有空格时,应使用的输入函数是
按照C语言规定的用户标识符命名规则,不能出现在标识符中的是
随机试题
弦脉的主要病有()(1991年第130题;1997年第132题;1999年第131题)
在华为VRP平台上,直连路由、OSPF、RIP、静态路由按照优先级从高到低的排序是________。
为女病人导尿,消毒尿道口及会阴顺序是
小儿末梢血中性粒细胞和淋巴细胞的比例相等的时间分别是
公司负责城市市区危改地块A的土地一级开发工作,甲公司委托乙公司承担拆迁业务。土地一级开发后收归市土地储备中心所有,并以住宅用地性质进行国有土地使用权拍卖。该地块的使用权由丙公司竞买得到。半年后,丙公司将该地块转让给丁公司。丁公司欲在该地块开发商业地产项目,
一般存款账户可以办理现金缴存,但不能办理现金支取。()
2015年7月甲公司购入一项商标权,入账价值1000万元,预计使用年限8年,法律有效年限为10年,按照直线法摊销,无残值。2016年12月31日因存在减值迹象,甲公司对该商标权进行减值测试,其公允价值减去处置费用后的净额为500万元,预计未来现金流量的现值
10月19日,甲公司职工李某因突发心脏病住院治疗。已知李某实际工作年限为12年,其中在甲公司工作年限为4年,李某依法可享受的医疗期为()。
在错误记忆的理论模型中,提出内隐激活反应假设的研究者是()
Youdon’twanttolagbehind,neitherdoesshe.
最新回复
(
0
)