首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序中,函数fun的功能是将带头节点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为:10、4、2、8、6,排序后链表结点数据域从头至尾的数据为:2、4、6、8、10。 请在程序的下划线处填入正确的内容并把下划线删
给定程序中,函数fun的功能是将带头节点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为:10、4、2、8、6,排序后链表结点数据域从头至尾的数据为:2、4、6、8、10。 请在程序的下划线处填入正确的内容并把下划线删
admin
2019-03-06
36
问题
给定程序中,函数fun的功能是将带头节点的单向链表结点数据域中的数据从小到大排序。即若原链表结点数据域从头至尾的数据为:10、4、2、8、6,排序后链表结点数据域从头至尾的数据为:2、4、6、8、10。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
#include
#include
#define N 6
typedef struct node {
int data;
struct node *next;
} NODE;
void fun (NODE *h)
{NODE *p,*q; int t;
while (p) {
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;
{ 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 is
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,8f 6 };
head=creatlist (a) ;
printf ("\nThe original list:\n") ;
outlist (head) ;
fun (head) ;
printf ("\nThe list after sorting:
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/XIRp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
请选出以下程序的输出结果()。#include<stdio.h>sub(int*s,inty){staticintt=3;y=s[t];t--;}main(){int
main(){floatx=123.456;printf("%-5.2f\n",x);}以上程序输出的结果是______。
在数据库的两级映射中,从概念模式到内模式的映射一般由______实现。
下列程序的运行结果为【】。main(){intx,y,z;X=12;y=012;z=0l2;printf("%d,%d,%d\n",x,y,z);}
程序的运行结果为【】。main(){charc1=’a’,c2=’b’,c3=’c’;printf("a%cb%c\tc%c\n",c1,c2,c3);}
_____________的目的是分析数据问内在语义关联,在此基础上建立一个数据的抽象模型。
阅读下述程序段:y=-1;if(x!=0)if(x>0)y=1;elsey=0;该程序段所描述的数学关系是()
下面程序的输出结果为()structst{intx;int*y;}*p;intdt[4]={10,20,30,40};structstaa[4]={50,&dt[0],6
若有定义:“inta=10,b=9,C=8;”接着顺序执行下列语句后,变量b中的值是________。c=(a-=(b-5)):c=(a%11)+(b=3);
随机试题
企业流动资金中最活跃的项目是()
下列句子中,含有使动用法的是()
某洗衣机生产企业为应对市场竞争,近年来一直以降低产品销售价格作为主要竞争策略。为了改善经营业绩,该企业拟调整竞争策略,并为此聘请一家咨询公司对当地洗衣机市场进行分析。咨询公司从委托单位得到了部分资料,见表6-6。
如果要减少项目进度计划的计算工期,可以采取的措施有()。
下图是某生态系统中的食物网简图,图中甲-庚分别代表不同的生物。问题:若此生态系统遭到重金属污染,体内积存重金属污染物最多的生物是________。
目前中国沙漠化较为严重,我国是世界上沙漠化受害最深的国家。()
设主存容量1MB,有16KB直接相联映像的Cache,假定该Cache的块为8个32位的字。解答下列问题:(1)写出Cache的地址格式;(2)写出主存的地址格式;(3)块表的容量有多大;(4)主存地址为DE8F8H的单元在Ca
A、 B、 C、 D、 A
设随机变量X与Y独立同分布,方差存在且不为零,记U=X-Y,V=X+Y,则U与V必然()
ButsomebookswouldcostmoremanIhave.ButIdidn’t______tobuysomebooks.
最新回复
(
0
)