【leetcode】-92. Reverse Linked List II 反转部分链表II python版

该博客介绍了如何使用递归法解决LeetCode上的92题,即反转链表的一部分。从给定位置m到n,提供了一段Python代码实现这一操作。例如,输入1->2->3->4->5->NULL,m=2,n=4,输出1->4->3->2->5->NULL。
摘要由CSDN通过智能技术生成

反转部分链表

题目

Reverse a linked list from position m to n. Do it in one-pass.

Note: 1 ≤ m ≤ n ≤ length of list.

Example:

Input: 1->2->3->4->5->NULL, m = 2, n = 4
Output: 1->4->3->2->5->NULL

递归法

1、首先递归写出反转全部链表;
2、然后在1基础上反转前n个元素链表;
3、然后在2基础上反转从m到n的链表。

python 代码

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def __init__(self):
        self.remain = None
        
        
    def reverseBetween(self, head: ListNode, m: int, n: int) -> ListNode:
        if m==1:
            return self.reverseN(head,n)
        head.next = self.reverseBetween(head.next,m-1,n-1)
        return head
        
     # 反转全部链表
    def reverse(self,head):
        if not head.next:
            return head
        last = self.reverse(head.next)
        head.next.next = head
        head.next = None
        return last
    
    # 反转前n个链表
    def reverseN(self,head,n):
        if n==1:
            self.remain = head.next
            return head
        last = self.reverseN(head.next,n-1)
        head.next.next = head
        head.next = self.remain
        return last
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值