结点单链表的插入和删除实验报告

appdata可以删除吗  时间:2021-04-27  阅读:()

实验一、单链表的插入和删除

一、 目的

了解和掌握线性表的逻辑结构和链式存储结构掌握单链表的基本算法及相关的时间性能分析。

一、要求

建立一个数据域定义为字符串的单链表在链表中不允许有重复的字符串根据输入的字符串先找到相应的结点后删除之。

三、程序源代码

#i nclude"stdio.h"

#i nclude"stri ng.h"

#i nclude"stdl ib.h"

#in clude"ctype.h"typedef struct node //定义结点

{char data[10]; //结点的数据域为字符串struct node*n ext; //结点的指针域

}ListNode;typedef ListNode*Lin kList; // 自定义LinkList单链表类型

Lin kList CreatListR1(); //函数用尾插入法建立带头结点的单链表

数据结构实验报告

ListNode*LocateNode(); //函数按值查找结点void DeleteList(); //函数删除指定值的结点void pr in tl ist(); //函数打印链表中的所有值void DeleteAl l(); //函数删除所有结点释放内存〃二=========主函数==============void mai n()

{charch[10], nu m[10];

Lin kList head;head=CreatListR1(); //用尾插入法建立单链表返回头指针prin tl ist(head); //遍历链表输出其值printf(”Delete node(y/n):"); 〃输入y”或“去选择是否删除结点sca nf("%s", nu m);if(strcmp(nu m,"y")==0 | |strcmp(nu m,"Y")==0){prin tf("Please in put Delete_data:");sca nf("%s",ch); //输入要删除的字符串

DeleteList(head,ch);pr in tl ist(head);

}

DeleteAl l(head); //删除所有结点释放内存}

2

数据结构实验报告

//==========用尾插入法建立带头结点的单链表

3

数据结构实验报告

LinkList CreatListRI(void)

{charch[10];

LinkList head=(LinkList)mal loc(sizeof(ListNode)); //生成头结点ListNode*s,*r,*pp;r=head;r->next二NULL;prin tf("I nput#to end"); //输入#”代表输入结束prin tf("Please in put Node_data:");sca nf("%s",ch); //输入各结点的字符串whi le(strcmp(ch,"#")!=O) {pp=LocateNode(head,ch); //按值查找结点返回结点指针if(pp==NULL) { //没有重复的字符串插入到链表中s=(ListNode*)mal loc(sizeof(ListNode));strcpy(s->data,ch);r->n ext=s;r=s;r->n ext=NULL;

}prin tf("I nput#to end");prin tf("Please in put Node_data:");

4

数据结构实验报告

sea nf("%s",ch);

}return head; //返回头指针

}

〃二=========按值查找结点找到则返回该结点的位置否则返

回NULL二=========

ListNode*LocateNode(L in kList head,char*key)

{

ListNode*p=head->next; //从开始结点比较whi le(p&&strcmp(p->data,key)!=O ) //直到p为NULL或p->data为key止p=p->n ext; //扫描下一个结点return p; //若p=NULL则查找失败否则p指向找到的值key

的结点

}

//========== 删除带头结点的单链表中的指定结点=======vo i dDeleteList(Li nkList head,char*key)

{

ListNode*p,*r,*q=head;p=LocateNode(head,key); //按key值查找结点的if(p==NULL) { //若没有找到结点退出prin tf("positi on error");

5

}whi le(q->next!二p) 〃p为要删除的结点 q为p的前结点q二q->n ext;r二q->n ext;q->n ext=r->n ext;fr e e(r); //释放结点

}

〃二二=========打印链表=======void pr in tl ist(L in kList head)

{

ListNode*p=head->next; //从开始结点打印wh i l e(p){prin tf("%s, ”,p->data);p=p->n ext;

}prin tf("\n");

}

//========== 删除所有结点释放空间===========void DeleteAI I(LinkList head)

{

LipsrtiNnotdf(e"i*npp=uhtethaed, i*nr;sert no de:");

6

数据结构实验报告

whi le(p->next){ r=p->n ext; free(p);p=r

}fr e e(p);

}

运行结果

加的添加结点的代码:int In sert(ListNode*head) // the in sert fun cti on

{

ListNode*in ,*p,*q;int wh;in=(ListNode*)mal loc(sizeof(ListNode)); in->next二NULL; p=(ListNode

*)mal loc(sizeof(ListNode));p->next=NULL; q=(ListNode

7

数据结构实验报告

*)mal loc(sizeof(ListNode));q->next二NULL; if(! i n)retu rn 0;sca nf("%s", i n->data);printf("input the place where you want to insert you data:");sca nf("%d",&wh);for(p=head;wh>0;p=p->n ext,wh--);q=p->n ext;p->n ext=in;in->n ext=q;retu rn 1 ;

}

运行结果:

prin tf("i nput the in sert node:");

8

数据结构实验报告

最后提示为OK添加成功

实验心得这个实验中 主要修改的是ch和num把它们由指针改成数组因为不改的话在后面 delect函数中会出现没有地址的情况找不到地址就不能执行功能 然后把locate函数的判断语句改一下避免矛盾的出现。

9

Megalayer美国独立服务器配置及性能速度综合评测

Megalayer 商家在之前也有记录过,商家开始只有提供香港站群服务器和独立服务器,后来也有增加到美国独立服务器,以及前几天也有介绍到有增加香港VPS主机。对于香港服务器之前有过评测(Megalayer香港服务器配置一览及E3-1230 8GB服务器评测记录),这里申请到一台美国独立服务器,所以也准备简单的评测记录。目前市场上我们看到很多商家提供VPS或者云服务器基本上没有什么特别的,但是独立服...

ZJI-全场八折优惠,香港服务器 600元起,还有日本/美国/韩国服务器

ZJI怎么样?ZJI是一家成立于2011年的商家,原名维翔主机,主要从事独立服务器产品销售,目前主打中国香港、日本、美国独立服务器产品,是一个稳定、靠谱的老牌商家。详情如下:月付/年付优惠码:zji??下物理服务器/VDS/虚拟主机空间订单八折终身优惠(长期有效)一、ZJI官网点击直达香港葵湾特惠B型 CPU:E5-2650L核心:6核12线程内存:16GB硬盘:480GB SSD带宽:5Mbps...

蓝速数据(58/年)秒杀服务器独立1核2G 1M

蓝速数据金秋上云季2G58/年怎么样?蓝速数据物理机拼团0元购劲爆?蓝速数据服务器秒杀爆产品好不好?蓝速数据是广州五联科技信息有限公司旗下品牌云计算平台、采用国内首选Zkeys公有云建设多种开通方式、具有IDC、ISP从业资格证IDC运营商新老用户值得信赖的商家。我司主要从事内地的枣庄、宿迁、深圳、绍兴、成都(市、县)。待开放地区:北京、广州、十堰、西安、镇江(市、县)。等地区数据中心业务,均KV...

appdata可以删除吗为你推荐
大学生就业信息获取与信息分析dominavimasios7支付apple支持ipad勒索病毒win7补丁怎么删除 防勒索病毒 打的补丁win10445端口windows server2008怎么开放4443端口win7telnetwindows7的TELNET服务在哪里开启啊phpecho为什么在PHP中使用echo FALSE;什么也输出不了?应该如何输出FALSE?谢谢!chromeframeicharts 怎么支持ie8android5.1安卓系统5.1好吗
域名升级访问中 河北服务器租用 阿里云搜索 日本软银 justhost 美国主机评论 韩国空间 mediafire下载 服务器日志分析 新站长网 免费smtp服务器 免费个人网站申请 铁通流量查询 美国十次啦服务器 秒杀预告 怎么测试下载速度 adroit vip购优惠 网通服务器托管 789电视剧 更多