首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序中,函数fun的功能是将不带头结点的单向链表逆置。即若原链表中从头至尾结点数据域依次为:2、4、6、8、10,逆置后,从头至尾结点数据域依次为:10、8、6、4、2。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源
给定程序中,函数fun的功能是将不带头结点的单向链表逆置。即若原链表中从头至尾结点数据域依次为:2、4、6、8、10,逆置后,从头至尾结点数据域依次为:10、8、6、4、2。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源
admin
2019-09-02
71
问题
给定程序中,函数fun的功能是将不带头结点的单向链表逆置。即若原链表中从头至尾结点数据域依次为:2、4、6、8、10,逆置后,从头至尾结点数据域依次为:10、8、6、4、2。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
#include <stdio.h>
#include <stdlib.h>
#define N 5
typectef struct node{
int data;
Struct riode*next;
}NODE;
/**********found**********/
___1___fun(NODE*h)
{NODE*p,*q,*r;
p=h;
if(p==NULL)
return NULL;
q=p->next;
p->next=NULL;
while(q)
{
/**********found**********/
r=q->___2___;
q->next=p;
p=q;
/**********found**********/
q=___3___;
}
return p;
}
NODE*creatlist(int a[])
{NODE*h,*p,*q;int i;
h=NULL;
for(i=0;i<N;i++)
{q=(NODE*)malloc(sizeof(NODE));
q->data=a
;
q->next=NULL;
if(h==NULL)h=p=q,
else{p->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 a[N]={2,4,6,8,10};
head=creatlist(a);
printf("\nfhe original list:\n");
outlist(head);
head=fun(head);
printf("\nThe list afterinverting:\n");
outlist(head);
}
选项
答案
(1)NODE* (2)next (3)r
解析
函数fun的功能是将不带头结点的单向链表逆置,链表的逆置从第二个结点开始,分别将结点的指针指向前一个结点便可完成单项链表的逆置。
第一空:主函数内fun函数调用形式是“head=fun(laead);”,变量head是NODE指针,故fun函数的返回值是NODE指针,即第一空处应为“NODE*”。
第二空:while循环完成链表的倒置,在循环体内,p、q和r指针分别指向三个连续的结点,p指针在最前,然后是q指针,r指针在最后。将q指针指向p结点,p和q两个结点倒置,然后p、q和r再往后移动一个结点,继续对其他结点逆置。因此,第二空处r是q的后面一个结点,故第二空处为“next”。
第三空:由第二空的分析可知,第三空处是将q结点往后移动一个结点位置,故第三空处为“r”。
转载请注明原文地址:https://kaotiyun.com/show/9ORp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
给定程序MODI1.C中函数fun的功能是:求出s所指字符串中最后一次出现的t所指子字符串的地址,通过函数值返回,在主函数中输出从此地址开始的字符串;若未找到,则函数值为NULL。例如,当字符串中的内容为:"abcdabfabedx",
人员的记录由编号和出生年、月、日组成,N名人员的数据已在主函数中存入结构体数组std中。函数fun的功能是:找出指定出生年份的人员,将其数据放在形参k所指的数组中,由主函数输出,同时由函数值返回满足指定条件的人数。请在程序的下划线处填入正确的内容
函数fun的功能是:从三个形参a,b,c中找出中间的一那个数,作为函数值返回。例如,当a=3,b=5,e=4时,中数为4。请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。注意:源程序存放在考生文件夹下的B
请编写函数fun,函数的功能是:移动一维数组中的内容:若数组中有n个整数,要求把下标从0到P(含P,P小于等于n-1)的数组元素平移到数组的最后。例如,一维数组中的原始内容为:1,2,3,4,5,6,7,8,9,10:p的值为3。移动后,一维数组
下列数据结构中,能用二分法进行查找的是
对如下二叉树进行后序遍历的结果为
若有以下程序,编译时出现错误,你认为出错的是#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
有以下程序main(){inta=1,b=2,c=3,x;x=(a^b)&c;’printf("%d\n",x);}程序的运行结果是
若要求从键盘读入含有空格字符的字符串,应使用函数
以下程序函数f的功能是:当flag为1时,进行由小到大排序;当flag为0时,进行由大到小排序voidf(intb[],intn,intflag){inti,j,t;for(i=0;i<n-1;i++)for(j=i+1j<
随机试题
简述情绪与情感的区别与联系。
消费者李华在购买冰箱时,在普通上二下双开门冰箱、三歼门冰箱和左右对开门冰箱之间进行权衡选择,这种不同类型冰箱之间的竞争关系属于【】
男,45岁,因晕厥被送急诊,体查:血压120/80mmHg,平卧位,心率86次/分,S1常,S2稍↑,L3、4SM4/6级收缩期喷射性杂音,双肺呼吸音清,无干湿性哕音。初步诊断为梗阻性肥厚型心肌病。该病的收缩期杂音的鉴别诊断不包括以下的哪一种
孙先生,38岁,对称性全身小关节肿痛反复发作5年,有晨僵,热水浸泡后减轻。化验类风湿因子阳性。拟诊为类风湿关节炎。随后发生双手指在掌指关节处向尺侧偏斜,应考虑
当混凝土抗压试件少于10组时,合格的抗压强度标准应是( )。
建设单位在办理工程质量监督注册手续时需提供的资料有()。
竣工验收的准备工作不包括()。
水运工程招标人自招标文件开始发售之日起至潜在投标人提交投标文件截止之日止最短不得少于()日。
村民李强于2007年11月1日向同村王甘借款1000元,双方约定以李强所有的母牛为质担保李强还钱,如果2008年6月1日不还款,母牛即转归王甘所有。2007年12月1日,王甘将牛牵回自家。12月15日,王甘发现牛生病,急忙找来兽医医治,虽牛复原,但花费医
Ofalltheareasoflearningthemostimportantisthedevelopmentofattitudes.Emotionalreactionsaswellaslogicalthought
最新回复
(
0
)