- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
链表操作
《数据结构》实验报告一
南京工业大学电子系
题目: 链表的基本操作 班级: 电子0602 学号: 1402050206 姓名: 王斯辉 日期: 程序名: 一、上机实验的问题和要求:
单链表的查找、插入与删除。设计算法,实现线性结构上的单链表的产生以及元素的查找、插入与删除。具体实现要求:
从键盘输入20个整数,产生不带表头的单链表,并输入结点值。
从键盘输入1个整数,在单链表中查找该结点的位置。若找到,则显示“找到了”;否则,则显示“找不到”。
从键盘输入2个整数,一个表示欲插入的位置i,另一个表示欲插入的数值x,将x插入在对应位置上,输出单链表所有结点值,观察输出结果。
从键盘输入1个整数,表示欲删除结点的位置,输出单链表所有结点值,观察输出结果。
将单链表中值重复的结点删除,使所得的结果表中个结点值均不相同,输出单链表所有结点值,观察输出结果。
删除其中所有数据值为偶数的结点,输出单链表所有结点值,观察输出结果。
把单链表变成带表头结点的循环链表,输出循环单链表所有结点值,观察输出结果。
(★)将单链表分解成两个单链表A和B,使A链表中含有原链表中序号为奇数的元素,而B链表中含有原链表中序号为偶数的元素,且保持原来的相对顺序,分别输出单链表A和单链表B的所有结点值,观察输出结果。
二、程序设计的基本思想,原理和算法描述:
(包括程序的结构,数据结构,输入/输出设计,符号名说明等)
这是一个带头结点的线性链表,数据域存放整形数据,由用户输入。头结点数据域存链表长度,所以程序中有个求链表长度的函数
int LengthList(LinkList L); //求链表长度
L是指向头结点的指针,将长度值存入语句为
L-data = LengthList(L);
为了实时观察链表情况,程序中有个输出链表数据的函数
void PrintList(LinkList L); //输出链表
程序可以实现8种不同的操作,这8种不同的操作由8个函数实现,分别是
void CreateList(LinkList L); //创建链表
void Locate(LinkList L); //查询数值
void InsertList(LinkList L); //插入数值
void DeleteList(LinkList L); //选择删除
void Deleterepeat(LinkList L); //删除重复结点
void DeleteEven(LinkList L); //删除数值为偶数的结点
void Rotate(LinkList L); //变为循环链表
void Divide(LinkList L); //分解成两个链表
这些基本操作的实现算法都比较简单,有些跟书本上一样,有些需要自己稍作思考才能写出,具体程序见第三部分
8种不同的操作可以由用户通过按A-H这八个字母键来选择,分别是 A:创建 B:查询 C:插入 D:选择删除 E:删除重复 F:删除偶数 G:变为循环链表 H:分解为两个链表,见第四部分输出截图,可以清晰的看到整个过程
主程序中用 开关语句实现:
char operate;
printf(\n\n输入字符选择链表操作类型\nA:创建 B:查询 C:插入 D:选择删除 E:删除重复 F:删除偶数 \nG:变为循环链表 H:分解为两个链表\n);
scanf(%c,operate);
switch (operate)
{
case a:
case A: CreateList(L);break;
case b:
case B: Locate(L);break;
case c:
case C: InsertList(L); break;
case d:
case D: DeleteList(L);break;
case e:
case E: Deleterepeat(L);break;
case f:
case F: DeleteEven(L);break;
cas
文档评论(0)