概念介绍

上一博文已经介绍了Python实现单向无序链表的实现方式,这篇博文来介绍Python如何实现单向有序链表。有序和无序仅仅指节点所包含的数据成员的大小排列顺序,有序指各个节点按照节点数据成员的大小顺序排序,从大到小或从小到大。无序则可以任意排列。

链表节点实现

实现方式完全同单向无序列表,这里不再过多介绍,感兴趣的可以看Python实现单向无序链表(Singly linked list)关于节点的实现方式。

链表实现

链表的实现中,链表初始化,判断是否为空,获取链表长度与无序链表一致。同时,remove方式的实现也相同,都是遍历链表,找到指定节点,然后删除。主要的区别在于查找和添加(search和add方法)有所区别。

在无序链表中,查找是依次遍历各个节点,直至找到该节点,若节点不存在于链表中,也会一直遍历直到链表尾部。对于有序链表来说,由于各个节点的数据成员是有大小排序的,则查找算法可以有所优化。假如有这样一个有序链表,链表中各个节点的数据依次为17,26,31, 54,77,93。是按从小到大的顺序依次排序。如果我们想查找节点数据成员为45的节点是否在链表中,当我们找到31所在的节点时,其下一个节点数据类型为54,而45正好在31和54之间,却没有在链表中找到,则45所在的节点不存在,且不需要再继续遍历链表,因为随后的节点数据成员都比54要大。如下图所示。

下面来实现其算法,依然是遍历各个节点,若找到则返回True,若当前节点的数据成员值>item,则为找到,不需要继续遍历后续节点,因为后续节点的值比当前节点的值还要大。

若当前节点的值

def search(self, item):

current = self.head

while current is not None:

if current.get_data() == item:

return True

if current.get_data() > item:

return False

else:

current = current.get_next()

return False

接下来实现有序链表的add(添加新节点)方法。注意,在无序列表中,新添加的节点成为了链首节点,这种实现方式很简单。但在有序链表中,添加方法必须在插入链表后,依然要保持整个链表的有序状态(从大到小或从小到大)。假如有这样一个链表,节点的大小顺序为17,26,54, 77,93,我们想将31添加到链表中,显然应该添加到26和54中间的位置。

下面介绍实现原理:首先要插入节点,必然有一个当前节点和上一个节点,分别用current和previous指代。最后的目的是将指定节点插入到当前节点和上一个节点中间。

首先遍历节点,若当前节点的值大于指定节点的值,而显然后续的节点值比当前节点的值更大,则链表终止遍历。指定节点的值显然在当前节点和上一节点之间。若当前节点的值比指定节点的值小,则继续遍历,直至到最后一个节点。最后判断若上一个节点为空,则当前节点为空或当前节点的值比指定节点的值大,直接将当前节点设置为指定节点,插入到链首。若上一个节点不为空,直接将指定节点插入到二者之间(当前节点和上一个节点)。

def add(self, item):

current = self.head

previous = None

while current is not None:

if current.get_data() > item:

break

previous = current

current = current.get_next()

temp = Node(item)

if previous is None:

temp.set_next(self.head)

self.head = temp

else:

temp.set_next(current)

previous.set_next(temp)

其他方法也可以按照类似的方式实现,其中pop方法同无序链表。

python创建一个有序链表_Python实现单向有序链表(Singly linked list)相关推荐

  1. 用python创建一个新文件_Python创建文件和追加文件内容实例

    一.用Python创建一个新文件,内容是从0到9的整数, 每个数字占一行: 代码如下: #python >>>f=open('f.txt','w') # r只读,w可写,a追加 &g ...

  2. python 创建一个空向量_Python之Django系列-创建第一个应用-5

    上一篇:Python之Django系列-创建第一个应用-4 这一章我们会讲到视图层怎么与数据库操作并返回数据到模板层进行渲染最终显示在页面上 投票应用基本上会有这么几个视图 问题列表页 问题详情页 问 ...

  3. python创建一个csv文件_python如何写入csv

    在使用python对文件操作的过程中,你肯定碰到过对csv文件的操作,下面就python对csv文件的操作进行详述. CSV(Comma-Separated Values)逗号分隔符,也就是每条记录中 ...

  4. python 创建一个空向量,python 创建一个空向量_python 创建一维的0向量实例

    python 创建一维的0向量实例 第一种方法: A=[0]*8 第二种方法: import numpy as np A=np.zeros(8) 以上这篇python 创建一维的0向量实例就是小编分享 ...

  5. python创建一个空集合_python空集合如何表示

    python中,用set来表示一个无序不重复元素的序列.set的主要作用就是用来给数据去重. 可以使用大括号 { } 或者 set() 函数创建集合,但是注意如果创建一个空集合必须用 set() 而不 ...

  6. python 创建一个空向量_python 创建一维的0向量实例

    python 创建一维的0向量实例 第一种方法: A=[0]*8 第二种方法: import numpy as np A=np.zeros(8) 以上这篇python 创建一维的0向量实例就是小编分享 ...

  7. python创建一个空集合_Python中如何创建集合

    #创作者招募令# 第六十七节:创建集合 集合作为序列形式的一种,在Python中也有应用. 先来看看集合在数学中的定义:集合(aggregate)是"确定的一堆东西",集合里的&q ...

  8. python创建一个csv文件_python操作csv文件

    1 importcsv2 data =[3 #使用数字和字符串的数字都可以 4 ("ken","mafe",23),5 ("Tame",&q ...

  9. python创建一个文件并写入_python创建文件并写入

    python怎么以追加的方式写文件? Python 3.5 想将从1到10写入一个文件并且自动换行 现在需要一个写文件方法,将selenium的脚本运行结果写入test_result.log文件中 首 ...

最新文章

  1. python初学之魔法方法1
  2. 梯度下降法 —— 经典的优化方法
  3. 在现有K8S集群上安装部署JenkinsX
  4. 北京邮电大学计算机学院交换组,李静林-交换骨干教师-网络与交换技术国家重点实验室...
  5. Laravel 5.5 使用 Jwt-Auth 实现 API 用户认证以及无痛刷新访问令牌
  6. 【Android开发—智能家居系列】(一):智能家居原理
  7. GCD 深入理解(一)
  8. 隐藏WIN10资源管理器中的3D对象文件夹
  9. 戴尔r510服务器修复,DELL R510服务器宕机案例(1)
  10. 生产排程系统_ASPROVA:工序排程软件的全球隐形冠军
  11. idear怎么设置自动导包
  12. 我喜欢的刀刀______扮演别人快乐么?
  13. 基于张量的多元多阶马尔科夫多模态预测方法
  14. 联想p720工作站安装linux,联想发布ThinkStation P920和P720工作站 采用至强处理器
  15. (1条消息) CodeForces 1278 B.A and B(Math)
  16. 用爬虫批量采集阿里巴巴1688商品数据
  17. Android ADB USB 驱动 万能配置方式
  18. vb如何实现两台计算机数据包传送,VB学习网站! - PLC论坛 工控网 工控论坛 http://bbs.gkong.com/...
  19. springboot整合shiro无法加载静态资源
  20. c语言课程设计——影院管理系统

热门文章

  1. 聚焦数智技术助力乡村振兴 京东云为乡村振兴注入“数智”力量
  2. 涉嫌内幕交易?美国SEC对马斯克展开调查
  3. 优酷股东变更 阿里通过全资子公司土豆继续持有优酷
  4. 转转集团二手双11大促:长沙用户“秒杀”99新iPhone12成首单
  5. 欧菲光修正2020年业绩为预计亏损18.5亿元
  6. 还在4S店买车?《Boss1+1》张朝阳对话贾鸣镝“种草”购车新方式
  7. 明天上线!部分开发者手机已安装鸿蒙OS:超流畅,可装安卓应用
  8. 苹果充电配件MagSafe Duo Charger现已发售
  9. 熊孩子倾家荡产玩游戏、打赏主播有救了!最高法:无效,可退还
  10. 百度AI实力响应“新基建”号召 Q1财报智能交通成绩亮眼