码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode 148 Sort List

时间:2014-10-22 12:55:55      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:java   leetcode   

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

思路:要想时间复杂度达到O(n log n) ,那么有两种,一种是合并排序,另一种是快速排序,而要想空间复杂度为常数,那么只能使用递归,本人使用的是递归的合并排序,代码如下:
/**
 * Definition for singly-linked list.
 * class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
   private ListNode merge(ListNode l1, ListNode l2) {
        if(l1==null&&l2==null) return null;
        ListNode head=new ListNode (-1);
        ListNode pNode=head;
        while(l1!=null||l2!=null){
			if(l1==null) {
				pNode.next=l2;
				return head.next;
			}
			if(l2==null){
				pNode.next=l1;
				return head.next;
			}
            if(l1.val>l2.val){
				pNode.next=l2;
				l2=l2.next;
            }else {
				pNode.next=l1;
				l1=l1.next;
            }
            pNode=pNode.next;                   
        }
        return head.next;
    }
   private ListNode mergeSort(ListNode head){
       if(head==null||head.next==null)   //just one element
           return head;
       ListNode p=head, q=head, pre=null;
       while(q!=null&&q.next!=null){
           q=q.next.next;
           pre=p;
           p=p.next;  //divide into two parts
       }
       pre.next=null;
       ListNode lhalf=mergeSort(head);
       ListNode rhalf=mergeSort(p);  //recursive
       return merge(lhalf, rhalf);   //merge
   }
    public ListNode sortList(ListNode head) {
        return mergeSort( head);
    }
}



LeetCode 148 Sort List

标签:java   leetcode   

原文地址:http://blog.csdn.net/mlweixiao/article/details/40373915

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!