首页 > 编程语言 > 详细

148. 排序链表

时间:2019-05-25 10:05:04      阅读:110      评论:0      收藏:0      [点我收藏+]

在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序。

示例 1:

输入: 4->2->1->3
输出: 1->2->3->4

示例 2:

输入: -1->5->3->4->0
输出: -1->0->3->4->5

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode sortList(ListNode head) {
        /**
        归并排序稳定O(NlogN), 但是容易出错, 需要注意细节
        **/
        return sort(head);
    }
    
    private ListNode sort(ListNode head) {
        // 用快慢指针找出中间节点并断开, 对断开后的两个链表分别排序后再合并
        if(head == null || head.next == null) return head;
        ListNode slow = head, fast = head, mid = head;
        while(fast != null && fast.next != null) {
            mid = slow;
            slow = slow.next;
            fast = fast.next.next;
        }
        mid.next = null;
        
        // head为左半部头节点, slow为右半部头结点
        ListNode lhead = sort(head);
        ListNode rhead = sort(slow);
        return merge(lhead, rhead);
    }
    
    private ListNode merge(ListNode lhead, ListNode rhead) {
        ListNode head = new ListNode(0);
        ListNode cur = head;
        while(lhead != null && rhead != null) {
            if(lhead.val <= rhead.val) {
                cur.next = lhead;
                lhead = lhead.next;
            }
            else {
                cur.next = rhead;
                rhead = rhead.next;
            }
            cur = cur.next;
        }
        if(lhead != null)
            cur.next = lhead;
        if(rhead != null)
            cur.next = rhead;
        return head.next;
    }
}

  

148. 排序链表

原文:https://www.cnblogs.com/Stefan-24-Machine/p/10921206.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!