python实现的基于单向循环链表插入排序

文章介绍了如何使用单向循环链表实现插入排序,避免了移动数据。排序过程仅需修改指针,随后顺序表变为链表。讨论了链表访问和查找的效率,并提供了两种将顺序表转换为有序表的方法。算法展示了顺序表与链表之间的转换机制,具有启发性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       相比于定义一个循环双向链表来实现插入排序来说,下面的实现采用一个单向循环链表来实现,并且不需要定义一个单向循环链表类,而是把一个list(数组/顺序表)当成单向循环链表来用,list的元素是一个包含两个元素的对象,一个是数值,一个是指向下一个list元素的指针(list的元素下标),list的第一个元素(下标为0的元素)是单链表的头结点,它不存放数据,起到哨兵的作用。

        排序的时候,把一个数据元素插入一个位置,不需要移动数据,只需要修改该位置前一个list元素和待插入数据元素的指针域就行,其实就是个单向链表的插入操作。

        通过一遍循环操作完成排序之后,顺序表就被链表化了。

        下面给出一个顺序表被链表化的过程的图示:

       可以很方便的按照访问链表的方式来完成对数据的有序(正序/逆序)遍历访问,但如果是执行查找,不能进行二分查找,只能顺序查找,效率不高,所以还需要把顺序表变成有序表。

        有两种方式来实现这一点。

        第一种,可以new一个空的list,遍历链表,依次把访问到的元素append到list中,最后返回这个list。

       第二种,就地对顺序表重排,实现的逻辑并不复杂,思路是依次取链表的数据元素把它们依次从前往后排在顺序表中,如果它们本身就在应该排的位置什么都不用做,取下一个数据元素继续,如果它们不在应该排的位置上,那么把它们和当前占着该位置的数据元素交换,并且把它们的指针域改

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

__空无一人__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值