Python 官方文档:入门教程 => 点击学习
给定一个单链表,将其反转。其实很容易想到,只需要修改每个结点的指针指向:即令后一个结点指向前一个结点,并且将表头指针指向最后一个结点即可。 这个过程可以用循环实现,也可以用递归来实
给定一个单链表,将其反转。其实很容易想到,只需要修改每个结点的指针指向:即令后一个结点指向前一个结点,并且将表头指针指向最后一个结点即可。
这个过程可以用循环实现,也可以用递归来实现。
1、用循环来实现:
class Lnode:
def __init__(self, elem):
self.elem = elem
self.pnext = None
def reverse(head):
if head is None or head.pnext is None: #如果输入的链表是空或者只有一个结点,直接返回当前结点
return head
pre = None #用来指向上一个结点
cur = newhead = head #cur是当前的结点。newhead指向当前新的头结点
while cur:
newhead = cur
temp = cur.pnext
cur.pnext = pre #将当前的结点的指针指向前一个结点
pre = cur
cur = temp
return newhead
if __name__=="__main__":
head = LNode(1)
p1 = LNode(2)
p2 = LNode(3)
head.pnext = p1
p1.pnext = p2
p = reverse(head)
while p:
print(p.elem)
p = p.pnext
2、用递归来实现:
class LNode:
def __init__(self, elem):
self.elem = elem
self.pnext = None
def reverse(head):
if not head or not head.pnext:
return head
else:
newhead = reverse(head.pnext)
head.pnext.pnext = head #令下一个结点的指针指向当前结点
head.pnext = None #断开当前结点与下一个结点之间的指针指向联系,令其指向空
return newhead
if __name__=="__main__":
head = LNode(1)
p1 = LNode(2)
p2 = LNode(3)
head.pnext = p1
p1.pnext = p2
p = reverse(head)
while p:
print(p.elem)
p = p.pnext
以下是图解递归的详细过程:
--结束END--
本文标题: Python实现单链表中元素的反转
本文链接: https://lsjlt.com/news/117644.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0