剑指Offer-链表-反转链表

本文详细解析了如何通过双指针技术反转链表,并提供了具体的Python代码实现。介绍了链表的特点,即只能从一个方向访问每个节点,以及如何通过改变节点指向来实现链表的反转。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

24. 反转链表

定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。

解题思路:

  • 链表特点:只能一个方向访问每个节点
  • 通过建立两个指针改变每个节点的指向

算法流程:

  • 申请两个节点,pre和cur,pre最初指向None,cur指向head
  • 遍历每个节点,调整每个节点的指向并且pre和cur不断前进

复杂度分析:

  • 空间复杂度:O(n)
  • 时间复杂度:O(1)

代码实现:

class Solution(object):
	def reverseList(self, head):
		#申请两个节点,pre和cur,pre最初指向None
		pre = None
		cur = head
		#遍历节点
		while cur:
			# 记录当前节点的下一个节点
			tmp = cur.next
			# 然后将当前节点指向pre
			cur.next = pre
			# pre和cur节点都前进一位
			pre = cur
			cur = tmp
		return pre
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值