重排链表

题目描述:给定一个单链表L: L0→L1→…→Ln-1→Ln, 重新排列后为:L0→Ln→L1→Ln-1→L2→Ln-2→…必须在不改变节点值的情况下进行原地操作

样例:给出链表1->2->3->4->null,重新排列后为1->4->2->3->null。

将L0,L1; L1,Ln-1;...排在一起,其实和回文链表(详见:点击打开链接)的逻辑是一样的,不同的是,回文链表是比较值,这里是通过“摘链”和“链接”的方法调整位置。

那思路就比较清楚了:和回文链表的做法一致,首先,通过“快慢指针法”(详见:点击打开链接)找到中间节点,将中间节点之后的部分翻转(也就是单链表逆置,详见:点击打开链接),最后,依次将被逆置部分的链表的节点插入相应位置。

其实还是以前的东西,不过综合在一起罢了。

那么代码并不难:

"""
Definition of ListNode
class ListNode(object):

    def __init__(self, val, next=None):
        self.val = val
        self.next = next
"""
class Solution:
    """
    @param head: The first node of the linked list.
    @return: nothing
    """
    def reorderList(self, head):
        if head is None or head.next is None:
            return head
        slow, fast = head, head.next
        # 找到中间节点
        while fast and fast.next:
            fast = fast.next.next
            slow = slow.next
        # 以中间节点为界,将链表断开,分成前后两部分
        # 断开的目的是方便链表翻转操作
        cur = slow.next
        slow.next = None
        # 单链表逆置
        while cur:
            temp = cur
            cur = cur.next
            temp.next = slow.next
            slow.next = temp
        # 再次断开成两个链表,合并
        second = slow.next
        slow.next = None
        pre = head
        while second:
            temp = second
            second = second.next
            temp.next = pre.next
            pre.next = temp
            pre = temp.next
        return head
        # write your code here
需要注意的是,两次将链表断开都是为了方便对节点的操作。第一次是方便了单链表逆置,第二次是方便了链表合并。这种先断开,再链接的方法我们之前用过很多了。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值