链表上篇简单介绍了链表,这篇用python实现链表的基本一些操作。
包括打印链表,插入,删除,查找,反转。
class Node():
def __init__(self, data, next=None):
self.data = data
self.next = next # next为下一节点的内存地址
class Linked_list():
def __init__(self):
self.head = None
def printList(self):
'''打印所有data'''
nums = list()
tmp = self.head
while tmp:
nums.append(str(tmp.data))
tmp = tmp.next
if len(nums) > 0:
print('->'.join(nums))
def insert_to_head(self, data):
'''链表头部插入'''
new_node = Node(data)
if self.head != None:
new_node.next = self.head
self.head = new_node # self.head要始终处于最前方
def insert_after(self, node, data):
'''指定节点后面插入'''
if (not isinstance(node, Node)):
print('node参数不为Node类')
return
if not node or not data:
print('node或data为空')
return
new_node = Node(data)
new_node.next = node.next
node.next = new_node
def insert_before(self, node, data):
'''指定节点前面插入'''
if (not isinstance(node, Node)):
print('node参数不为Node类')
return
if not node.data or not data:
print('node或data为空')
return
if node == self.head:
self.insert_to_head(data)
print('before head插入成功')
return
current = self.head
while current.next and current.next != node:
current = current.next
# 循环终止两个情况,第一current.next为空,说明node节点没有找到
if not current.next:
print('node不存在')
return
# 第二current.next 此时就是 node
new_node = Node(data)
new_node.next = node
current.next = new_node
def find_by_value(self, data):
'''根据数值data寻找,返回data所在节点地址'''
p = self.head()
while p and p.data != data:
p = p.next
if not p:
print('未找到值为%s的节点' % data)
return
return p
def find_by_index(self, data):
'''根据数值索引,寻找第data个节点'''
p = self.head
position = 0
while p and position != data:
p = p.next
position += 1
if not p:
print('索引值%s已超过链表长度' % data)
return
return p
def delete_by_node(self, node):
'''根据节点删除'''
current = self.head
if not isinstance(node, Node):
print('node参数不为Node类')
return
if not current or not node:
print('链表为空或node为空')
return
while current and current.next != node:
current = current.next
if not current:
print('未找到匹配的节点')
return
current.next = node.next
def delete_by_value(self, data):
'''根据数值删除'''
current = self.head
if not current or not data:
print('链表为空或data为空')
return
if self.head.data == data:
self.head = self.head.next
print('head已删除')
return
while current.next and current.next.data != data:
current = current.next
if not current.next:
print('未找到匹配的data')
return
current.next = current.next.next
def reverse_self(self):
'''单链表反转'''
if not self.head or not self.head.next:
print('链表为空或链表只有一个节点,不用反转')
return
node1 = self.head
node2 = self.head.next
while node2:
tmp = node2.next
node2.next = node1
node1 = node2
node2 = tmp
self.head.next = None
self.head = node1
尝试运行代码,结果如下:
A = Linked_list()
A.insert_to_head(2)
A.insert_to_head(3)
A.insert_to_head(4)
A.printList()
# 打印结果为:
# 4->3->2
A.insert_after(A.head.next,5)
A.printList()
# 打印结果为:
# 4->3->5->2
A.reverse_self()
A.printList()
# 打印结果为:
# 2->5->3->4
单链表反转
上面的链表翻转代码写的比较容易理解,其实有更简便的写法,和上面思路一致,不过需要仔细思考才能理解。
下面代码写的是一个单独的函数,而不是像上面的类中的函数,请注意。传入的参数是head节点。
def reverse_self(head):
'''单链表反转'''
if (head is None) or (head.next is None):
print('链表为空或链表只有一个节点,不用反转')
return head
node1 = None
node2 = head
while node2:
node1, node1.next, node2 = node2, node1, node2.next
# 最后node1变成head节点,返回node1
return node1
最初设定的node1=None,None最后会被反转变成尾节点的next。而随着node1的不断迭代反转,node1最后会变成head节点。
本文详细介绍了使用Python实现链表的基本操作,包括插入、删除、查找、反转等关键功能,并通过具体代码示例展示了如何创建和操作链表,适合初学者理解和掌握链表数据结构。
1153

被折叠的 条评论
为什么被折叠?



