leetcode-编程-反转链表

递归反转链表的一部分思路

一、递归反转整个链表

剑指 Offer 24. 反转链表 -重点

题目
递归题解

class Solution(object):
	def reverseList(self, head):
		"""
		:type head: ListNode
		:rtype: ListNode
		"""
		# 递归终止条件是当前为空,或者下一个节点为空
		if(head==None or head.next==None):
			return head
		# 这里的cur就是最后一个节点
		cur = self.reverseList(head.next)
		# 这里请配合动画演示理解
		# 如果链表是 1->2->3->4->5,那么此时的cur就是5
		# 而head是4,head的下一个是5,下下一个是空
		# 所以head.next.next 就是5->4
		head.next.next = head
		# 防止链表循环,需要将head.next设置为空
		head.next = None
		# 每层递归函数都返回cur,也就是最后一个节点
		return cur

双指针迭代题解
在这里插入图片描述

# 双指针迭代
class Solution:
    def reverseList(self, head: ListNode) -> ListNode:
        if head==None or head.next==None:
            return head 
        pre=None
        cur=head 
        while cur:
            tmp=cur.next
            cur.next=pre 
            pre=cur
            cur=tmp 
        return pre 

二、反转链表前 N 个节点

三、反转链表的一部分

四、最后总结

92. 反转链表 II

题目
题解
在这里插入图片描述

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def reverseBetween(self, head: ListNode, m: int, n: int) -> ListNode:
        def reverseN(head,n):
            if n == 1:
                return head
            # 以 head.next 为起点,需要反转前 n - 1 个节点
            last = reverseN(head.next, n-1)
            successor = head.next.next 
            # 以head.next为开头的链表已经完成翻转,那么head.next.next正确指向后继节点
            head.next.next = head
            head.next = successor
            return last
        if m == 1:return reverseN(head,n)
        head.next = self.reverseBetween(head.next,m-1,n-1)
        return head

剑指 Offer 06. 从尾到头打印链表-简单

题目
题解

class Solution:
    def reversePrint(self, head: ListNode) -> List[int]:
        if not head :
            return []
        res=[]
        while head:
            res.append(head.val)
            head=head.next 
        return res[::-1]
class Solution:
    def reversePrint(self, head: ListNode) -> List[int]:
        return self.reversePrint(head.next)+[head.val] if head else[]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值