LeetCode----Reverse Linked List II

95 篇文章 0 订阅
93 篇文章 0 订阅

Reverse Linked List II

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

For example:
Given 1->2->3->4->5->NULLm = 2 and n = 4,

return 1->4->3->2->5->NULL.

Note:
Given mn satisfy the following condition:
1 ≤ m ≤ n ≤ length of list.


代码:

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


class Solution(object):
    def reverseBetween(self, head, m, n):
        """
        :type head: ListNode
        :type m: int
        :type n: int
        :rtype: ListNode
        """
        if m == n:
            return head
        mid = None  # 代表中间的串的头部
        right = None  # 代表尾串的头部
        p = head
        index = 0
        if m == 1:
            while p:
                index += 1
                if index == n:
                    right = p.next
                    p.next = None
                    break
                p = p.next
            mid = self.reverseList(head)
            head = mid
            p = self.getLastNode(mid)
            p.next = right
        else:
            pre = None
            ppre = None
            while p:
                index += 1
                if index == m:
                    ppre = pre
                    ppre.next = None
                    mid = p
                if index == n:
                    right = p.next
                    p.next = None
                    break
                pre = p
                p = p.next
            mid = self.reverseList(mid)
            mid_l = self.getLastNode(mid)
            ppre.next = mid
            mid_l.next = right
        
        return head

    def getLastNode(self, head):
        p = head
        while p.next:
            p = p.next
        return p

    def reverseList(self, head):
        pre, cur = None, head
        while cur:
            cur.next, pre, cur = pre, cur, cur.next
        return pre


------------------------------------------------------------------------------------------------------------------------------------------

2016-05-01补充:

代码:

class Solution(object):
    def reverseBetween(self, head, m, n):
        """
        :type head: ListNode
        :type m: int
        :type n: int
        :rtype: ListNode
        """
        if m == n:
            return head
        dummy = ListNode(0)
        dummy.next = head
        leftpre = dummy
        for i in range(m - 1):
            leftpre = leftpre.next
        pre = leftpre.next  # 此时的leftpre记录的为第m个节点
        mid = pre.next
        post = None
        for i in range(n - m):  # 进行第m个节点到第n个节点的链表反转
            post = mid.next
            mid.next = pre
            pre = mid
            mid = post
        leftpre.next.next = mid
        leftpre.next = pre
        return dummy.next


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值