软件技术基础上机实验报告(链表)

软件技术基础上机实验报告(链表)

ID:11497320

大小:162.50 KB

页数:9页

时间:2018-07-12

软件技术基础上机实验报告(链表)_第1页
软件技术基础上机实验报告(链表)_第2页
软件技术基础上机实验报告(链表)_第3页
软件技术基础上机实验报告(链表)_第4页
软件技术基础上机实验报告(链表)_第5页
资源描述:

《软件技术基础上机实验报告(链表)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

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+1

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==

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。