美文网首页
148. Sort List

148. Sort List

作者: lqsss | 来源:发表于2018-01-09 23:58 被阅读0次

Sort a linked list in O(n log n) time using constant space complexity.

思想

归并排序 n O(logn)
快慢指针找到单链表的中点

代码

package linkList;

/**
 * Sort a linked list in O(n log n) time using constant space complexity.
 * Created by liqiushi on 2018/1/9.
 */
public class SortList {
    public ListNode sortList(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        //使用快慢指针分割
        ListNode slow = head;
        ListNode fast = head;
        ListNode prev = null;
        while (fast != null && fast.next != null) {
            prev = slow;
            slow = slow.next;
            fast = fast.next.next;
        }
        //链表截断  head->prev->null、slow->fast->null/slow-null
        prev.next = null;
        ListNode l1 = sortList(head);
        ListNode l2 = sortList(slow);
        return merge(l1, l2);
    }

    public ListNode merge(ListNode l1, ListNode l2) {
        ListNode result = new ListNode(0);
        ListNode rptr = result;
        ListNode pptr = l1;
        ListNode qptr = l2;
        //遍历l1、l2
        while (pptr != null && qptr != null) {
            if (pptr.val <= qptr.val) {
                rptr.next = pptr;
                pptr = pptr.next;
            } else {
                rptr.next = qptr;
                qptr = qptr.next;
            }
            rptr = rptr.next;
        }
        if (pptr != null) {
            rptr.next = pptr;
        } else {
            rptr.next = qptr;
        }
        //若其中一个队列遍历完毕
        return result.next;
    }
}


相关文章

  • 2019-01-13

    LeetCode 148. Sort List Description Sort a linked list in...

  • LeetCode #148 2018-07-28

    148. Sort List Sort a linked list in O(n log n) time usin...

  • 链表排序问题

    148. Sort List(链表归并排序)Sort a linked list in O(n log n) ti...

  • 148. Sort List

    嗯 stack 的办法很low对不对。 阿里当时面试官提示的一种基于二分法的一种办法,类似于快排。。二分 归并代码如下:

  • 148. Sort List

    https://leetcode.com/problems/sort-list/description/ Both...

  • 148. Sort List

    Sort a linked list in O(n log n) time using constant spac...

  • 148. Sort List

    题目 Sort a linked list in O(n log n) time using constant s...

  • 148. Sort List

    My Submissions Total Accepted: 90190Total Submissions: 33...

  • 148. Sort List

    这题就是merge sort的链表实现。先看一下mergeSort: 复杂度O(nlogn)。这题的解法我看了ht...

  • 148. Sort List

    Sort a linked list in O(n log n) time using constant spac...

网友评论

      本文标题:148. Sort List

      本文链接:https://www.haomeiwen.com/subject/ojdnnxtx.html