一、实验目的
- 链表的基本操作
- 链表的算法设计
- 链表的应用
二、实验内容
- 链表插入算法
- 链表的删除算法
- 移动链表中的最大值到尾部
- 合并两个递增有序的单循环链表
- 链表中奇偶结点的移动
- 多项式的加法
三、实验环境
在PTA平台进行实验
四、实验要求
根据每个实训的要求完成代码提交和测评
五、实验步骤
描述算法的思路原理或实现流程(测评完全正确或部分正确的实训)
6-1 链表的插入算法
本题要求实现一个插入函数,实现在链表llist中的元素x之后插入一个元素y的操作。
将y的指针指向x的后继,再将x的指针指向y
6-2 链表的删除算法
本题要求实现一个函数,实现删除链表llist中的指定元素deldata。
创建一个新节点,将新节点的指针指向要删除结点,再将要删除结点的前驱节点的指针指向新节点的后继结点,然后释放要删除的结点。
6-3 移动链表中的最大值到尾部
编写函数MoveMaxToTail(),实现查找单链表中值最大的结点,并将其移动到链表尾部,注意其他结点的相对次序不变。要求尽量具有较高的时间效率。
例如输入8 12 46 30 5,输出为8 12 30 5 46
首先写一个找最大值的函数,并生成两个新结点,将链表遍历一遍寻找最大值并将其中一个新结点p指向链表最后一个结点,将另一个新结点q的指针指向最大结点,将最大值结点的前驱结点指针指向最大值结点的后继结点,再将最大值结点的指针赋空。根据q找到最后一个结点再将p结点的指针赋给链表最后一个结点,然后释放结点p和q
6-4 合并两个递增有序的单循环链表
本题要求实现一个合并函数,实现对有序单循环链表tail1和tail2的合并,要求合并时实现去重操作,即合并后的链表中没有重复的元素,并且合并后的链表为递增有序链表。
因为是有序链表,所以不用再写一个新函数给两个链表排序。
具体想要把tail2的元素写入tali1中而不是再新建一个tali3,这样可以减小空间复杂度。新建三个空指针,p指向tali1的头节点,q指向tali2的头节点,然后开始比较两个指针指向的结点的数值大小。
当p指向的的元素比q指向的元素大时,将t指向该结点,q继续指向下一个结点,将p的指针赋给t指向的结点的指针,再将t的指针赋空。
当p指向的元素比q指向的元素小时,q指针不变,p指针指向该节点的后继结点,继续比较。
当P指向的元素比q指向的元素一样时,t指向该结点,p和q都指向它的后继结点,再将此节点释放。
当p指向的元素为空q指向的元素不为空时,直接将q的指针赋给p指向的元素的指针
如此重复,直至tali2为空,合并完成。
6-5 链表中奇偶结点的移动
本题要求实现一个函数,实现对单循环链表中奇数和偶数结点的移动,要求奇数在前面,偶数在后面,且结点之间的相对顺序不变。
创建三个空结点p,q和t,p指向头节点,q指向p,当p指向的结点是奇数时,p继续指向下一个结点,q指向此结点,当
p下一个结点时偶数时,q不动,p继续向下移动
p下一个结点为奇数且q指向的结点的下一结点指向的不是p时,把p的后继结点赋给t,p指向其后继结点的后继,t指向的结点指针指向q的后继,再将q指向t指向的结点,然后将t的指针赋空。
一直做此循环直至P指向空
7-1 多项式的加法
用链表表示多项式,并实现多项式的加法运算
输入格式:输入在第一行给出第一个多项式POLYA的系数和指数,并以0,0 结束第一个多项式的输入;在第二行出第一个多项式POLYB的系数和指数,并以0,0 结束第一个多项式的输入。
输出格式:对每一组输入,在一行中输出POLYA+POLYB和多项式的系数和指数。
结点应有数值:xushu zhishu
将链表遍历一遍,每当结点中zhishu相等时将其摘出,建立一个新列表,等链表遍历结束后会出现所有指数对应的链表。
然后将每个链表对应的xishu进行加减运算,得到新结点并把之前的结点释放掉
最后再将所有得到的新节点按顺序排序,得到结果