首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
给定程序中已建立一个带有头结点的单向链表,链表中的各结点按数据域递增有序链接。函数fun的功能是:删除链表中数据域值相同的结点,使之只保留一个。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生
给定程序中已建立一个带有头结点的单向链表,链表中的各结点按数据域递增有序链接。函数fun的功能是:删除链表中数据域值相同的结点,使之只保留一个。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生
admin
2015-06-08
46
问题
给定程序中已建立一个带有头结点的单向链表,链表中的各结点按数据域递增有序链接。函数fun的功能是:删除链表中数据域值相同的结点,使之只保留一个。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:源程序存放在考生文件夹下的BLANKl.C中。
不得增行或删行,也不得更改程序的结构!
#inolude
#include
#define N 8
typedef struct list
{ int data;
struct list *next;
}SLIST;
void fun(SLIST *h)
{SLIST *P,*q;
p=h一>next;
if(P!=NULL)
{ q=p->next;
while(q!=NULL)
{ if(P一>data==q一>data)
{P一>next=q一>next ;
/**********found***********/
free( ___1____ );
/**********found***********/
q=p一> ___2___ ;
}
elSe
{p=q;
/**********found***********/
q=q一>____3_____ ;
}
}
}
}
SLIST *creatlist(int*a)
{SLIST *h,*P,*q;int i;
h=p=(SLIST*)malloc(sizeof(SLIST));
for(i=0; i
{ q=(SLIST*)malloc(sizeof(SLIST));
q一>data=a
; P一>next=q;p=q;
}
P一>next=0;
return h;
}
void outlist(SLIST *h)
{SLIST *P;
p=h一>next;
if(p==NULL)printf(“\nThe list
is NULL!\n”);
else
{printf(“\nHead”);
do{printf(“一>%d”,P一>data);
p=p一>next;)while(P!=NULL);
printf(“一>End\n”);
}
}
main()
{SLIST *head;int a[N]={1,2,2,3,4,
4,4,5};
head=crearlist(a);
printf("\nThe list before deleting:
\n");outlist(head);
fun(head);
printf(“\nThe list after deleting:
\n”); outlist(head);
}
选项
答案
(1)q (2)next (3)next
解析
函数fun的功能是删除链表中数据域值相同的结点,只保留一个。
第一空:p和q是两个SLIST结构体指针,分别指向两个相邻的结点。“if(p->data==q一>data)”成立则应该删除其中一个结点,“p->next=q一>next;”p指向q的下一个结点,那么q结点就可以删除了,因此第一一空处应该为“free(q);”。
第二空:在第一空处,q指向的结点已经被删除,如果要继续循环搜索数据域值相同的结点,那么q需要重新指向p的下一个结点,因此第二空处应该为“q=p->next;”。
第三空:如果“if(p->data==q->data)”不成立,那么p和q都向结点尾移动一个结点位置,因此第三空处应该是“q=q->next;”。
转载请注明原文地址:https://kaotiyun.com/show/kiJp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
若有如下程序:sub(p,n)int(*p)[3],n;{inti;for(i=0;i<=n;i++)printf("%d",p[i][2]);}main(){ints[3][3]={1,2,
若有如下程序:main(){intn;for(n=0;n<9;n++){if(n<1){printf("%d",n);continue;}if(n==4)break;printf("%d
下面程序的输出结果是()。#definePI3.1415#defineARE(X)PI*x*xmain(){intr=2;printf("%.2f",ARE(r+1));}
实型数据在计算机中表示的方法有()。
若x、y、z、m均为int型变量,则执行下面语句后m的值是()。m=1;x=2;y=3;m=(m<x)?m:x;m=(m<y)?m:y;m=(m<y)?m:z;
有以下程序段:main(){inta=5,*b,**c;c=&b;b=&a;}程序在执行了c=&b;b=&a;语句后,表达式**c的值是______。
下面的程序片段y=-1;if(x!=0)if(x>0)y=1;elsey=0;所表示的数学函数关系是_______。
在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是_______。
实现程序可将磁盘中的一个文件复制到另一个文件中,两个文件的文件名在可执行命令的命令行中(相当于copy命令),假定文件在当前目录下。请补全程序。#include<stdio.h>voidmain(intargc,char*argv[])
若有说明inti,j=2,*p=&i;,则能完成i=j赋值功能的语句是______。
随机试题
领导绩效是多种因素综合作用的结果。这是指领导绩效的()
男性60岁,腰痛3周,无明显外伤史,X线片示第三腰椎椎体破坏,压缩楔形变,椎间隙正常。最可能的诊断是
下列哪种胃炎急性期严禁行胃镜检查
A.尊重患者的生命价值,确立双向作用的医患关系B.医患关系的整体性、稳定性、直接性C.整体化发展趋势和综合化发展趋势D.医患关系的分解趋势和物化趋势E.扩大医学服务的范围,但仍以医生为权威
《献血法》规定,献血者两次献血的时间间隔不得少于
中国药典规定,应检查重金属及有害元素的药材是()。
资料1广州美能达实业发展有限公司(企业编码4401940098),委托广州对外贸易进出口公司(企业编码4401910069)进口其投资额以内的设备(INTERNET访问服务器)一批,该批设备属于《外商投资产品指导目录》中的鼓励项目,减免税证明号为
纯种马是昂贵的商品。一种由遗传缺陷引起的疾病威胁着纯种赛马,使它们轻则丧失赛跑能力,重则瘫痪甚至死亡。因此,赛马饲养者认为,一旦发现有此种缺陷的赛马应停止饲养。这种看法是片面的。因为一般地说,此种疾病可以通过饮食和医疗加以控制。另外,有此种遗传缺陷的赛马往
在使用Kerberos进行密钥管理的环境中,有N个人,为确保在任意两个人之间进行秘密对话,系统所需的最少会话密钥数为(50)个。
以下程序运行后的输出结果是______。main(){charc1,c2;for(c1=’0’,c2=’9’;c1<c2;c1++,c2--)printf("%c%c",c1,c2);printf("\n");}
最新回复
(
0
)