我是stackoverflow和Python语言的新手,我有一个问题。我知道如何在Python中实现单链表,但在使用双链表时遇到了麻烦,更具体地说,是插入到双链表的中间。有没有人能帮我写代码来做这件事?谢谢
发布于 2012-11-13 07:54:17
我也是,我是Python的新手,但我希望我能帮助你。所以如果我没记错的话,假设你有一些(经典的)链表实现,如下所示:
# Simple LinkedList class
class LinkedList:
def __init__(self, data, prev=None, next=None):
self.data = data
self.prev = prev
self.next = next
# Just a string representation
def __str__(self):
if self.next:
return '%s %s' % (str(self.data), self.next.__str__())
else:
return '%s' % str(self.data)通过从链表的末端到中间同时迭代,您可以很容易地将一个元素插入到中间,知道链表的末端。当迭代器相交时,添加元素:
# Insert to middle logic
def insertToMiddle(data, left, right):
# Iterate
while True:
# Test for intersection
if left.next is right:
node = LinkedList(data, left, right)
left.next = node
right.prev = node
return
elif left is right:
node = LinkedList(data, left.prev, right.next)
left.next = node
right.next.prev = node
return
# Next iteration
left = left.next
right = right.prev
# This doesn't actually execute for a right call
if not left or not right:
return下面,您可以看到在插入之前和之后的链表创建及其表示:
# Sample list creation
node1 = LinkedList(1)
node2 = LinkedList(2,node1)
node3 = LinkedList(3,node2)
node4 = LinkedList(4,node3)
node1.next = node2
node2.next = node3
node3.next = node4
# Test
print node1
insertToMiddle(5, node1, node4)
print node1
insertToMiddle(6, node1, node4)
print node1
insertToMiddle(7, node1, node4)
print node1输出:
1 2 3 4 #initial
1 2 5 3 4 #inserted 5
1 2 5 6 3 4 #inserted 6, notice it's right to middle
1 2 5 7 6 3 4 #inserted 7备注:如果你的列表有奇数个元素(比方说2 3 4),插入到中间是不确定的,所以上面的函数会直接添加到中间的右边(2 3元素4)
https://stackoverflow.com/questions/13352976
复制相似问题