单链表结构:

链表是一种物理存储单元上非连续、非顺序的存储结构数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。对于python来说指针就是指向下一个对象。

单链表时间复杂度:

创建空表:O(1)

删除表:O(1)

判断空:O(1)

加入:

首端加入:O(1)

尾端加入:O(n)

定位加入:O(n)

删除:

首端删除:O(1)

尾端删除:O(n)

定位删除:O(n)

其他删除:O(n)

扫描定位遍历都需要价差一批表节点,其时间复杂度收到节点数约束。

  

单链表 实现:

 class LinkedListUnderflow(ValueError): #自定义链表为空异常类
pass class Lnode(object):
def __init__(self,ele,next=None):
self.ele = ele
self.next = next class Dlist(object):
def __init__(self):
self.head = None def is_emtpy(self): #链表是否为空
if self.head == None: return True def last_append(self,ele): #尾插入
p = Lnode(ele=ele) if self.is_emtpy():
self.head = p
return last_p = self.head
while last_p.next: #找到尾部后插入
last_p = last_p.next
last_p.next = p def head_append(self,ele): #头插入
p = Lnode(ele=ele) if self.is_emtpy():
self.head = p
return p.next = self.head
self.head = p def head_pop(self):
if self.is_emtpy():
raise LinkedListUnderflow("链表为空") if self.head.next == None: #只有一个节点
self.head = None
return self.head = self.head.next def last_pop(self):
if self.is_emtpy():
raise LinkedListUnderflow("链表为空") if self.head.next == None: # 只有一个节点
self.head = None
return p = self.head
while p.next.next: #找到倒数第二个节点
p = p.next
p.next = None def print_all(self): #输出所有元素
if self.is_emtpy():
print("链表为空")
return last_p = self.head
while last_p:
print(last_p.ele)
last_p = last_p.next

单链表

循环单链表:

python中的循环单链表,实际就是尾部(tail)节点的指针指向head对象。所以循环单链表实现中只需要实现self.tail而头部即为self.tail.next,以此形成循环进行节点操作。

循环单链表实现

 class LooDlist(object):
def __init__(self):
self._real = None def is_emtpy(self):
return self._real is None def head_append(self,ele):
p = Lnode(ele=ele) if self.is_emtpy():
self._real = p
p.next = self._real #建立一个列表循环
return p.next = self._real.next #在首部添加新节点
self._real.next = p def last_append(self,ele):
self.head_append(ele)
self._real = self._real.next #将尾部指针向后移一位 def pop(self): #前端弹出
if self.is_emtpy():
raise LinkedListUnderflow("链表为空") if self._real.next == self._real: #只有一个节点
print(self._real.ele)
self._real = None
return value = self._real.next.ele
self._real.next = self._real.next.next #弹出前端节点,尾部指针指向弹出节点的next对象
return value def print_all(self):
if self.is_emtpy():
return p = self._real.next
while True:
print(p.ele)
if p is self._real:
break
p = p.next

双向链表:

双向链表实现:

#双向链表

class Delement(object):
def __init__(self,ele,next=None,pre=None):
self.ele = ele
self.next = next
self.pre = pre class Bllist(object):
def __init__(self):
self.head = None
self.real = None def Empty(self): #清空链表
self.head = None
self.real = None def head_append(self,ele): #前端增加
p = Delement(ele=ele,next=self.head) if not self.head: #链表为空
self.head = p
self.real = p
return self.head.pre = p
self.head = p def last_append(self,ele): #尾端增加
p = Delement(ele=ele,pre=self.real) if not self.real:
self.head = p
self.real = p
return self.real.next = p
self.real = p def head_pop(self): #前端删除
if not self.head:
raise ValueError("列表为空") value = self.head.ele
if self.head == self.real: #只有一个元素清空
self.Empty()
return value self.head = self.head.next
self.head.pre = None
return value def last_pop(self):
if not self.real:
raise ValueError("列表为空") value = self.real.ele
if self.head == self.real:
self.Empty()
return value self.real = self.real.pre
self.real.next = None
return value def printall(self): #输出所有元素值
p = self.head
while p != self.real:
print(p.ele)
p = p.next if p: #链表是否为空
print(p.ele)

链表反转

原理:原链表相当于一摞书,将这摞书最上面的一本拿下来 放在一个位置B, 再拿一本再放在位置B的最上面,重复这个过程。


class Lnode(object):
def __init__(self, ele, next=None):
self.next = next
self.ele = ele class Dlist(object):
def __init__(self):
self.head = None def head_append(self, ele): # 头插入
p = Lnode(ele=ele)
if not self.head:
self.head = p
return
p.next = self.head
self.head = p def reverse(self):
q = None #新链表 while True: #从原链表中拿到一个元素放入新链表
p = self.head #剔除原链表最上方的元素
self.head = self.head.next if p == None: #原链表没元素了
break p.next = q #将剔除元素放入新的链表
q = p self.head = q #将反转的链表给原链表 def printall(self):
p = self.head
while p != None:
print(p.ele)
p = p.next a = Dlist()
for i in range(10):
a.head_append(i) a.reverse()
a.printall()
 

python描述:链表的更多相关文章

  1. 杂项之python描述符协议

    杂项之python描述符协议 本节内容 由来 描述符协议概念 类的静态方法及类方法实现原理 类作为装饰器使用 1. 由来 闲来无事去看了看django中的内置分页方法,发现里面用到了类作为装饰器来使用 ...

  2. python描述符(descriptor)、属性(property)、函数(类)装饰器(decorator )原理实例详解

     1.前言 Python的描述符是接触到Python核心编程中一个比较难以理解的内容,自己在学习的过程中也遇到过很多的疑惑,通过google和阅读源码,现将自己的理解和心得记录下来,也为正在为了该问题 ...

  3. 【转载】Python 描述符简介

    来源:Alex Starostin 链接:www.ibm.com/developerworks/cn/opensource/os-pythondescriptors/ 关于Python@修饰符的文章可 ...

  4. python描述符descriptor(一)

    Python 描述符是一种创建托管属性的方法.每当一个属性被查询时,一个动作就会发生.这个动作默认是get,set或者delete.不过,有时候某个应用可能会有 更多的需求,需要你设计一些更复杂的动作 ...

  5. python描述符 descriptor

    descriptor 在python中,如果一个新式类定义了__get__, __set__, __delete__方法中的一个或者多个,那么称之为descriptor.descriptor通常用来改 ...

  6. Python描述符的使用

    Python描述符的使用 前言 作为一位python的使用者,你可能使用python有一段时间了,但是对于python中的描述符却未必使用过,接下来是对描述符使用的介绍 场景介绍 为了引入描述符的使用 ...

  7. Python描述符 (descriptor) 详解

    1.什么是描述符? python描述符是一个“绑定行为”的对象属性,在描述符协议中,它可以通过方法重写属性的访问.这些方法有 __get__(), __set__(), 和__delete__().如 ...

  8. Python描述器引导(转)

    原文:http://pyzh.readthedocs.io/en/latest/Descriptor-HOW-TO-Guide.html 1. Python描述器引导(翻译) 作者: Raymond ...

  9. LeetCode初级算法的Python实现--链表

    LeetCode初级算法的Python实现--链表 之前没有接触过Python编写的链表,所以这里记录一下思路.这里前面的代码是和leetcode中的一样,因为做题需要调用,所以下面会给出. 首先定义 ...

  10. 算法之python创建链表实现cache

    算法之python创建链表实现cache 本节内容 问题由来 解决思路 实现代码 总结 1. 问题由来 问题起因于朋友的一次面试题,面试公司直接给出两道题,要求四十八小时之内做出来,语言不限,做出来之 ...

随机推荐

  1. Linux面试题-8

    1.Linux文件系统的文件都按其作用分门别类地放在相关的目录中,对于磁盘这种外部设备文件,一般应将其放在(C)目录中. A./bin B./etc C./dev D./lib 2.当使用mount进 ...

  2. 百万年薪python之路 -- MySQL数据库之 永久修改字符串编码 与 忘了密码和修改密码

    永久修改字符集编码的方法: 在mysql安装目录下创建一个my.ini(Windows下)文件,写入下面的配置,然后重启服务端. [client] #设置mysql客户端默认字符集 default-c ...

  3. linux 下ln命令--笔记

    linux 下ln命令 ln命令用来为文件创建连接,连接类型分为硬连接和符号连接两种,默认的连接类型是硬连接.如果要创建符号连接必须使用"-s"选项.注意:符号链接文件不是一个独立 ...

  4. 一次PHP代码上线遇到的问题

    exception ‘CDbException’ with message ‘The table “pms_goods” for active record class “PmsGoods” cann ...

  5. web前端面试题(含答案)

    HTML+CSS1.对WEB标准以及W3C的理解与认识标签闭合.标签小写.不乱嵌套.提高搜索机器人搜索几率.使用外 链css和js脚本.结构行为表现的分离.文件下载与页面速度更快.内容能被更多的用户所 ...

  6. (一)初识EasyTouch

    Easy Touch是一个手指触控(可以鼠标)的插件,可以非常方便的实现各种功能,使用插件第一步是添加Easy Touch组件,可以右键添加也可以在一个空的游戏物体上添加Easy Touch脚本(非事 ...

  7. Mycat分布式数据库架构解决方案--配置defaultAccount属性报错解决方案

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 该文章 ...

  8. 使用linq实现回调函数

    通过输入的Id找到parentId是该Id的列表,然后找到parentId是上面那个Id的列表,以此类推,找到第一目录下所有子目录的的列表. 通过传入第一目录的Id,得到该目录下的所有子目录. 通过回 ...

  9. (24)ASP.NET Core EF查询(查询的工作原理、跟踪与非跟踪查询)

    1.查询生命周期 在进入正题时候,我们先来了解EF Core查询的生命周期. 1.1LINQ查询会由Entity Framework Core处理并生成给数据库提供程序可处理的表示形式(说白了就是生成 ...

  10. CSPS模拟 75

    我身边 mikufun:矩阵树学学学 Lrefrain:矩阵题刷刷刷 Dybala:神仙定理康康康 skyh:讨论讨论讨论(most mei face) DeepinC:我过样例了! Mouding: ...