[本文出自天外归云的博客园]

链表是由节点构成的,一个指针代表一个方向,如果一个构成链表的节点都只包含一个指针,那么这个链表就是单向链表。

单向链表中的节点不光有代表方向的指针变量,也有值变量。所以我们定义链表,就是要定义链表中的节点,对链表的操作最后也就是对节点的操作。

这些包含数据的节点们在一种指定的结构下连接起来,成为了一种数据结构——单向链表。以上是我对单向链表的理解。

以下是我用python3对单向链表这种数据结构的一种实现,其中我用到了生成器来完成逆转单向链表这一操作,非常pythonic啊!代码如下:

'''
Python版单向链表-单向链表简称单链表
单链表中所包含的基本操作:
初始化
创建
链表生成器
打印
显示调用过程
计算长度
判空
获取
删除
插入
修改
追加
逆转单向链表
''' class Node(object):
# 节点初始化
def __init__(self, value, p=None):
self.value = value
self.next = p class LinkList(object):
# 初始化单链表
def __init__(self):
self.head = None # 创建单链表
def create(self, node_value_list):
self.head = Node(node_value_list[0])
p = self.head
for i in node_value_list[1:]:
p.next = Node(i)
p = p.next # 生成单链表
def generate(self):
p = self.head
while p != None:
yield p.value
p = p.next # 打印单链表
def print(self):
print([i for i in self.generate()]) # 显示方法调用前后的单链表
def show(func):
def wrapper(self, *args):
print("方法{func_name}执行前".format(func_name=func.__name__))
self.print()
print("方法{func_name}执行中".format(func_name=func.__name__))
func(self, *args)
print("方法{func_name}执行后".format(func_name=func.__name__))
self.print() return wrapper # 获取单链表的长度
def length(self):
p = self.head
length = 0
while p != None:
length += 1
p = p.next
return length # 判断单链表是否为空
def is_null(self):
return self.length() == 0 # 获取单链表偏移位元素返回并打印其节点值
# 支持顺序索引和逆序索引:0代表索引0位,-1代表倒数第一位,-2代表倒数第二位
# 获取不存在的位返回None
def get(self, offset):
p = self.head
index = 0
length = self.length()
if offset > length - 1:
print(None)
return None
if offset < 0 and offset + length < 0:
print(None)
return None
if offset < 0 and offset + length >= 0:
offset = length + offset
while index < length - 1 and index < offset:
p = p.next
index += 1
print("获取索引{index}位节点-值为{value}".format(index=index, value=p.value))
return p # 删除单链表偏移位元素并打印
# 支持顺序索引和逆序索引:0代表索引0位,-1代表倒数第一位,-2代表倒数第二位
# 删除不存在的位返回None
@show
def remove(self, offset):
p = self.head
length = self.length()
index = 0
if offset > length - 1:
print(None)
return None
if offset == 0 or offset + length == 0:
print("删除索引{index}位节点-值为{value}".format(index=index, value=self.head.value))
self.head = p.next
return None
if offset < 0 and length + offset > 0:
offset = length + offset
while index < length - 1 and index < offset - 1:
p = p.next
index += 1
print("删除索引{index}位节点-值为{value}".format(index=index + 1, value=p.next.value))
p.next = p.next.next # 在指定index位插入节点-值为value
# 什么是插入——在两个节点之间加入才叫插入
# 所以在末尾插入的意思就是在索引倒数第二位和倒数第一位之间插入
@show
def insert(self, offset, value):
length = self.length()
# 如果偏移量对应的索引位不在链表对应索引位范围内-返回None
if offset > length - 1 or offset + length < 0:
return None
if offset < 0:
offset = offset + length
node = Node(value)
if offset == 0 or offset + length == 0:
p = self.head
self.head = node
node.next = p
else:
previous_node = self.get(offset - 1)
current_node = self.get(offset)
previous_node.next = node
node.next = current_node
print("在索引{index}位插入节点-值为{value}".format(index=offset, value=value)) # 在链表索引末位追加一个节点-值为value
@show
def append(self, value):
last_node = self.get(self.length() - 1)
last_node.next = Node(value) # 修改链表索引位节点值
@show
def modify(self, offset, value):
self.get(offset).value = value # 逆向生成单向链表
@show
def reverse(self):
# 将节点生成器转变为列表并逆序
reverse_list = [i for i in self.generate()][::-1]
self.head = Node(reverse_list[0])
p = self.head
for i in reverse_list[1:]:
p.next = Node(i)
p = p.next if __name__ == '__main__':
list = [1, 2, 33, 4, 55, 6, 76, 78]
# 初始化链表
link_list = LinkList()
# 创建链表
link_list.create(list)
# 获取节点
link_list.get(-1)
# 删除节点
link_list.remove(0)
# 插入节点
link_list.insert(-2, 0.2)
# 末位追加节点
link_list.append(3)
# 修改节点值
link_list.modify(-1, 666)
# 逆转
link_list.reverse()

Python3玩转单链表——逆转单向链表pythonic版的更多相关文章

  1. 逆转单向链表看这一篇就够了【JAVA】

    逆转单向链表 逆转前: 1 -> 2 -> 3 -> 4 -> 5 -> null 逆转后: 5 -> 4 -> 3 -> 2 -> 1 -> ...

  2. 《Java数据结构》链表结构(单向链表,双向链表)

    单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始:链表是使用指针进行构造的列表:又称为结点列表,因为链表是由一个个结点组装起来的:其中每个结点都有指 ...

  3. python数据结构链表之单向链表

    单向链表 单向链表也叫单链表,是链表中最简单的一种形式,它的每个节点包含两个域,一个信息域(元素域)和一个链接域.这个链接指向链表中的下一个节点,而最后一个节点的链接域则指向一个空值. 表元素域ele ...

  4. C语言 链表的使用(链表的增删查改,链表逆转,链表排序)

    //链表的使用 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include< ...

  5. C++实现企业链表(单向链表的另外一种实现方式)

    LinkList.h #include <windows.h> #include <stdio.h> // 链表小结点 typedef struct LINKNODE { LI ...

  6. python中的单向链表实现

    引子 数据结构指的是是数据的组织的方式.从单个数据到一维结构(线性表),二维结构(树),三维结构(图),都是组织数据的不同方式. 为什么需要链表? 顺序表的构建需要预先知道数据大小来申请连续的存储空间 ...

  7. JAVA单向链表实现

    JAVA单向链表实现 单向链表 链表和数组一样是一种最常用的线性数据结构,两者各有优缺点.数组我们知道是在内存上的一块连续的空间构成,所以其元素访问可以通过下标进行,随机访问速度很快,但数组也有其缺点 ...

  8. C 单向链表就地逆转

    1.问题描述 给定一个单链表L,设计函数Reverse将L就地逆转.即不需要申请新的节点,将第一个节点转换为最后一个结点,第二个节点转换为倒数第二个结点,以此类推. 2.思路分析 循环处理整个链表.将 ...

  9. PTA 6-1 单链表逆转

    本题是一个非常经典的题目:单链表逆转. 这是链表结点的定义: typedef struct Node *PtrToNode; struct Node { ElementType Data; /* 存储 ...

随机推荐

  1. du命令解决linux磁盘空间满的问题(很不错的哦)

    首先你要确定是不是真正的是因为数据空间占满磁盘,经常是因为某个程序的日志占满了空间.当发现磁盘满了以后不要着急,使用以下命令从根目录开始排除查找哪个文件夹最大: du --max-depth=1 找到 ...

  2. C语言学习笔记 (004) - 数组名和数组首地址(转)

    一个变量有地址,一个数组包含若干元素,每个数组元素都在内存中占用存储单元,它们都有相应的地址.指针变量既然可以指向变量,当然也可以指向数组和数组元素(把数据起始地址或某一元素的地址放到一个指针变量中) ...

  3. 【转载】web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法

    原文:http://blog.csdn.net/csdn100861/article/details/50684438 问题描述 部署到服务器后访问发现页面展示不正常,但是刷新之后就会展示正常. 问题 ...

  4. Ubuntu 13.04 SSH其他机器连接慢的解决办法

    原来Windows上用Xshell,用这比较爽,命令open http,自动打开自己定义的http服务器SSH 远程连接,点一下文件传输,如果装了xsftp,自动启动xsftp,没有就来个提示,打开一 ...

  5. [转]IDEA 导出自己的jar包 并且在另一个工程中引用

    1.导出jar包 1.1 idea导出jar包不如eclipse方便,但是熟练了也很容易操作 1.2 File -> Project Settings -> Artifacts(艺术品) ...

  6. CSS中易忽略的点

    一.使用斜杠/分割的关键字 1.font H2{ font:12px/100% sans-serif; } 分割的分别是 字体大小 与 行高 ,其他关键是用空白符分割. 2.background di ...

  7. Appium升级后安装UnicodeIME-debug.apk 提示

    使用appium1.8 ,启动app过程中报错: 2018-05-08 17:09:16:890 - [W3C] Encountered internal error running command: ...

  8. EndNote 输出样式模板(根据国家标准制订)

    EndNote 输出样式模板(根据国家标准制定)   EndNote 相当于一个数据库,将添加/导入的文献存档.需要引用文献的时候就从中选择一个插入到文档中,EndNote 会自动给你编号.在文档末尾 ...

  9. python3 元类编程的一个例子

    [引子] 虽然我们可以通过“class”语句来定义“类”,但是要想更加细粒度的控制“类”的创建,要使用元类编程才能实现. 比如说我们要实现这样的一个约束.所有项目中用到的类都应该要为它定义的方法提供文 ...

  10. idea没有代码自动提示功能和包自动引入不了问题

    idea没有代码自动提示功能和包自动引入不了问题 原因:节电模式 File -> Power Save Mode (被勾选了) 处理方法: File -> Power Save Mode ...