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

ops/2024/10/20 18:31:17/

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

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

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

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

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

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

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

       第二种,就地对顺序表重排,实现的逻辑并不复杂,思路是依次取链表的数据元素把它们依次从前往后排在顺序表中,如果它们本身就在应该排的位置什么都不用做,取下一个数据元素继续,如果它们不在应该排的位置上,那么把它们和当前占着该位置的数据元素交换,并且把它们的指针域改成交换出去的数据元素交换到的位置,当后续对被交换出去的数据元素排位的时候,根据它前一结点指针域访问的是它在顺序表中旧(最初)的位置,需要从现在占用它旧位置的数据元素的指针域去取它的当前位置,但有可能在前面的排位过程中它的位置被调换了多次,因此这可能是一个连锁式的查找过程,这个算法的复杂性全在这一点上了。

       下面给出一个顺序表重排变成一个有序表的过程的图示:

      下面给出代码实现:

python">def sortwrap(inplace=True):def inner(f):if inplace:def sort(source):source = f(source)next = source[0][1]for i in range(1, len(source)):if i != next:source[i], source[next] = source[next], source[i]next, source[i][1] = source[i][1], nextelse:next = source[i][1]while next <= i and next != 0:next = source[next][1]return sourceelse:def sort(source):source = f(source)pos = source[0][1]result = []while pos != 0:result.append(source[pos][0])pos = source[pos][1]return resultreturn sortreturn inner@sortwrap()
def _insertsort(source):if not source:return source_source = [[0, 0]]_source += [[i, 0] for i in source]head = _source[0]head[1] = 1_source[1][1] = 0for i in range(2, len(_source)):prev = headwhile _source[prev[1]] is not head:if _source[i][0] < _source[prev[1]][0]:_source[i][1] = prev[1]prev[1] = ibreakelse:prev = _source[prev[1]]else:_source[i][1] = prev[1]prev[1] = ireturn _sourceprint(_insertsort((49, 38, 65, 97, 76, 13, 27, 52)))

       这个算法的亮点是实现了顺序表和链表的互转,挺有启发意义的。  


http://www.ppmy.cn/ops/27220.html

相关文章

《QT实用小工具·四十三》历史编辑器(支持历史搜索 关键字匹配)

1、概述 源码放在文章末尾 该项目实现了在输入框中输入部分信息能全部展现之前的历史输入信息&#xff0c;支持历史搜索和关键词匹配&#xff0c;项目demo演示如下所示&#xff1a; 项目部分代码如下所示&#xff1a; #include "historymodel.h" #include <QM…

Oracle 存过 与Postgresql 的存过的差别

一、Oracle 存储过程 CREATE OR REPLACE PROCEDURE display_employees_with_cursor AS -- 声明游标 CURSOR emp_cursor IS SELECT employee_id, first_name, salary FROM employees; -- 声明变量来存储从游标中检索的数据 v_employee_id employees.employee_id%TYPE; …

Pytorch基础:torch.load_state_dict()方法在加载时不会检查类型

相关阅读 Pytorch基础https://blog.csdn.net/weixin_45791458/category_12457644.html?spm1001.2014.3001.5482 笔者在使用torch.nn.module的load_state_dict中出现了一个问题&#xff0c;一个被注册的张量在加载后居然没有变化&#xff0c;一开始以为是加载出现了问题&#…

推荐一个wordpress免费模板下载

首页大背景图&#xff0c;首屏2张轮播图&#xff0c;轮换展示&#xff0c;效果非常的炫酷&#xff0c;非常的哇噻&#xff0c;使用这个主题搭建的wordpress网站&#xff0c;超过了200个&#xff0c;虽然是一个老主题了&#xff0c;不过是经得起时间考验的&#xff0c;现在用起来…

Oracle数据常驻程序内存优化【数据库实例优化系列三】

Oracle程序常驻程序内存优化【数据库实例优化系列二】-CSDN博客 在生产中,为提高用户的访问速度。可以将经常使用的表常驻与内存中。避免频繁的访问磁盘,降低IO。 虽然会占用一定的内存,但是效果还是很明显的。 如果不是用了,DBA可以将其删除。 一、数据缓冲池 数据库…

CentOS/Anolis的Linux系统如何通过VNC登录远程桌面?

综述 需要在server端启动vncserver&#xff0c;推荐tigervnc的server 然后再本地点来启动client进行访问&#xff0c;访问方式是IPport&#xff08;本质是传递数据包到某个ip的某个port&#xff09; 然后需要防火墙开启端口 服务器上&#xff1a;安装和启动服务 安装服务 y…

PotatoPie 4.0 实验教程(32) —— FPGA实现摄像头图像浮雕效果

什么是浮雕效果&#xff1f; 浮雕效果是一种图像处理技术&#xff0c;用于将图像转换为看起来像浮雕一样的效果&#xff0c;给人一种凸起或凹陷的立体感觉&#xff0c;下面第二张图就是图像处理实现浮雕效果。 不过这个图是用Adobe公司的PS人工P图实现的&#xff0c;效果比较…

前端开发工程师——Vue

Vue学习笔记&#xff08;尚硅谷天禹老师&#xff09;_尚硅谷天禹老师vue2021讲课笔记下载-CSDN博客 模板语法 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" co…