欢迎来到天天文库
浏览记录
ID:11497320
大小:162.50 KB
页数:9页
时间:2018-07-12
《软件技术基础上机实验报告(链表)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、ex2:链表的插入与删除1)首先创建一个单链表:从键盘读入五个整数,按输入顺序形成单链表。将创建好的链表元素依次输出到屏幕上。2)在已创建好的链表中插入一个元素:从键盘读入元素值和插入位置,调用插入函数完成插入操作。然后将链表元素依次输出到屏幕上。3)在已创建好的链表中删除一个元素:从键盘读入欲删除的元素位置(序号),调用删除函数完成删除操作。然后将链表元素依次输出到屏幕上。4)从键盘任意输入一个整数,在单链表中查询该数,如果单链表中已经存在这个数,就调用删除函数,删除该元素所在结点,并将单链表在删除前后的数据元素依次输出到屏幕上;如果单链表中不存在
2、这个数,就调用插入函数,将这个数插入到单链表尾,并将单链表在插入前后的数据元素依次输出到屏幕上软件技术基础上机实验报告姓名:肖燕平学号:2011019090028上机实验二Ex2_1(链表的创建和插入删除)#include#includetypedefstructnode_type//定义链点{intdata;structnode_type*next;}node_type;typedefstructlist_type//定义链表{node_type*head;node_type*tail;intlength;}l
3、ist_type;intread(){intx;scanf("%d",&x);returnx;}voiderror(intx){switch(x){case1:printf("theplaceofthedataiswrong,pleaseinputtheplaceagain");break;}}voidcreat_list(list_type*lianbiao)//创建链表{node_type*p,*s;//注意此处的指针要为链点结构体类型intx;lianbiao->head=(node_type*)malloc(sizeof(node_t
4、ype));lianbiao->length=0;p=lianbiao->head;while(lianbiao->length<5)//输入五个数{scanf("%d",&x);s=(node_type*)malloc(sizeof(node_type));s->data=x;p->next=s;p=s;//在链点连接上出现了问题导致后面显示链表时也出问题lianbiao->length++;}p->next=NULL;lianbiao->tail=p;}voidshow_list(list_type*lianbiao)//把链表元素打印出来{no
5、de_type*p;p=lianbiao->head->next;printf("Thelinkedlistis");while(p!=NULL){printf("%d",p->data);p=p->next;//p往下走一步}printf("Thelengthofthislinkedlistis%d",lianbiao->length);}voidinsert_list(list_type*lianbiao,intnewdata,intplace){node_type*newnode,*p;inti=0;newnode=(nod
6、e_type*)malloc(sizeof(node_type));newnode->data=newdata;p=lianbiao->head;while(lianbiao->length+17、8、place<1)//判断插入的位置是否正确{error(1);place=read();//位置错误则重新输入位置}while(inext;i++;}newnode->next=p->next;//插入链点p->next=newnode;if(newnode->next==NULL)9、{lianbiao->tail=newnode;//若插入的位置为表尾,则改变尾指针}lianbiao->length++;}voiddelete_list(list_type*lianbiao,intplace){inti=0;node_type*p,*g;p=lianbiao->head;while(place>lianbiao->length10、11、place<1)//检查删除元素的位置是否符合要求{error(1);place=read();}while(inext;i++;}g=p-12、>next;p->next=p->next->next;//删除链点free(g);if(p->next==
7、
8、place<1)//判断插入的位置是否正确{error(1);place=read();//位置错误则重新输入位置}while(inext;i++;}newnode->next=p->next;//插入链点p->next=newnode;if(newnode->next==NULL)
9、{lianbiao->tail=newnode;//若插入的位置为表尾,则改变尾指针}lianbiao->length++;}voiddelete_list(list_type*lianbiao,intplace){inti=0;node_type*p,*g;p=lianbiao->head;while(place>lianbiao->length
10、
11、place<1)//检查删除元素的位置是否符合要求{error(1);place=read();}while(inext;i++;}g=p-
12、>next;p->next=p->next->next;//删除链点free(g);if(p->next==
此文档下载收益归作者所有