一、概念梳理
链表是计算机科学里面应用应用最广泛的数据结构之一。它是最简单的数据结构之一,同时也是比较高阶的数据结构(例如棧、环形缓冲和队列)
简单的说,一个列表就是单数据通过索引集合在一起。在C里面这叫做指针。比方说,一个数据元素可以由地址元素,地理元素、路由信息活着交易细节等等组成。但是链表里面的元素类型都是一样的,是一种特殊的列表。
一个单独的列表元素叫做一个节点。这些节点不像数组一样都按顺序存储在内存当中,相反,你可以通过一个节点指向另外一个节点的指针在内存不同的地方找到这些元素。列表最后一项习惯用NIL表示,相当于python里面的None
这里介绍两种不同的列表——单链表和双链表。双链表中的某个节点只会指向列表中的下一个元素,但是在双链表里面,当前节点同时也会指向前一个节点。所以双链表会占用更多的内存,因为它需要额外的变量去存储索引
图一、单链表
图2:双链表
单链表可以从头到尾顺序查询,但是反过来就不是那么容易了。然而,双链表不管你是从哪个节点开始,从任意方向查询都是一样的。在单链表中增加和删除节点只需要两步,但是在双链表里就需要四步了。
但是在python里面没有提供像双链表一样的数据结构,所以我们可以自己创建一个这样的数据结构
二、如果使用python创建链表
(1).将节点定义成一个数据结构
首先我们将节点类定义成ListNode,该类在初始化实例对象时,定义了两个实例变量,其中data用来存储节点的值,next用来存储下一个节点的索引,下面详细介绍一下一个节点要定义的方法和属性
__init__():初始化节点 self.data:存储节点的值 self.next:存储指向下一个节点的索引 has_value():将当前节点值和其他的值比较
上面的方法和属性涵盖了一个节点应有的基本属性和行为
Listing1:The ListNode class
上面创建了最简单的节点类,下面初始化ListNode的对象
Listing2:初始化节点
上面创建了三个独立的节点
(2)创建一个单链表类
现在我们定义一个名为SingleLinkedList的类去管理我们的节点,它包含了下面这些方法:
__init__():初始化对象 list_length():返回节点数量 output_list():输出节点值 add_list_item():在列表末尾增加一个新的节点 unordered_search():根据一个特殊值去查询列表 remove_list_item_by_id():根据节点id移除节点
下面一一讲解这些方法
__init__()定义了head和tail,都初始化为None
Listing3:The SingleLinkedList class(part one)
(3)、添加节点
通过add_list_item()添加列表元素。先检测是不是ListNode的实例,如果不是,就新建一个节点。如果列表还是空的话,就把该节点当作头节点,如果不是空,就将当前节点指向下一个元素(也就是刚新添加的节点)。把新节点添加到列表当中
Listing4:The SinglelinkedList class(part two)
list_length()方法计算节点数量,返回列表的长度。在一个循环当中循环列表,self.next依次指向下一个节点
Listing5:The SingleLinkedList class(part three)
output_list()用来输出新的节点值
Listing6:The SingleLinkedList class(part four)
下面我们初始化SingleLinkedList的实例track,然后创建4个节点。
(4)查询列表
查询整个列表使用unordered_search()。它需要使用一个额外的参数帮助查询。列表的头是切入点。
(5)、从列表中移除一个元素
从列表中移除一个节点 时,指向该节点索引需要被移动到,被移除节点的下一个节点。被移除的节点会由python的垃圾回收机制清除
Listing10:Removing a node by node number
(6)、创建一个双链表
创建双链表其实就是在ListNode的基础上,在创建一个previous的属性
Listing11:Extended list node class
然后我们就可以依据上面的定义新建一个双链表类
添加新的节点跟单链表有所不同
移除双链表中的节点
python实际运用
输出结果
(7)、使用队列实现双向列表
问题内容: 使用Java中的链表实现堆栈的最佳方法是什么? 编辑:我将最好的定义为最有效的使用干净的代码。我已经使用数组来实现堆栈,但是对链接列表不熟悉,因此想知道是否有人可以帮助我实现类似于以下内容的内容: 编辑:如果有人感兴趣,这是链表的实现。 问题答案: 假设您真的想从头开始,而不是使用现有的完美堆栈实现之一,那么我建议您: 创建一个“ MyStack ”类,该类实现所需的任何接口(也许列出
本文向大家介绍Python 实现链表实例代码,包括了Python 实现链表实例代码的使用技巧和注意事项,需要的朋友参考一下 Python 实现链表实例代码 前言 算法和数据结构是一个亘古不变的话题,作为一个程序员,掌握常用的数据结构实现是非常非常的有必要的。 实现清单 实现链表,本质上和语言是无关的。但是灵活度却和实现它的语言密切相关。今天用Python来实现一下,包含如下操作: 生成这样的一个方
本文向大家介绍Java单链表基本操作的实现,包括了Java单链表基本操作的实现的使用技巧和注意事项,需要的朋友参考一下 最近被问到链表,是一个朋友和我讨论Java的时候说的。说实话,我学习编程的近一年时间里,学到的东西还是挺少的。语言是学了Java和C#,关于Web的学了一点Html+css+javascript。因为比较偏好,学习WinForm时比较认真,数据库操作也自己有所研究。但链表这个东西
本文向大家介绍python如何对链表操作,包括了python如何对链表操作的使用技巧和注意事项,需要的朋友参考一下 链表 链表(linked list)是由一组被称为结点的数据元素组成的数据结构,每个结点都包含结点本身的信息和指向下一个结点的地址。 由于每个结点都包含了可以链接起来的地址信息,所以用一个变量就能够访问整个结点序列。 也就是说,结点包含两部分信息:一部分用于存储数据元素的值,称为信息
本文向大家介绍python实现单向链表详解,包括了python实现单向链表详解的使用技巧和注意事项,需要的朋友参考一下 本文研究的主要是Python中实现单向链表的相关内容,具体如下。 什么是链表 链表顾名思义就是~链 链表是一种动态数据结构,他的特点是用一组任意的存储单元存放数据元素。链表中每一个元素成为“结点”,每一个结点都是由数据域和指针域组成的。跟数组不同链表不用预先定义大小,而且硬件支持
本文向大家介绍Java 数据结构链表操作实现代码,包括了Java 数据结构链表操作实现代码的使用技巧和注意事项,需要的朋友参考一下 链表是一种复杂的数据结构,其数据之间的相互关系使链表分成三种:单链表、循环链表、双向链表,下面将逐一介绍。链表在数据结构中是基础,也是重要的知识点,这里讲下Java 中链表的实现, JAVA 链表操作:单链表和双链表 主要讲述几点: 一、链表的简介 二、链表实现原理