[LintCode] Insertion Sort List

Sort a linked list using insertion sort.

Example

Given 1->3->2->0->null, return 0->1->2->3->null.

 

 1 /**
 2  * Definition for ListNode.
 3  * public class ListNode {
 4  *     int val;
 5  *     ListNode next;
 6  *     ListNode(int val) {
 7  *         this.val = val;
 8  *         this.next = null;
 9  *     }
10  * }
11  */ 
12 public class Solution {
13     /**
14      * @param head: The first node of linked list.
15      * @return: The head of linked list.
16      */
17     public ListNode insertionSortList(ListNode head) {
18         if(head == null || head.next == null){
19             return head;
20         }
21         ListNode dummy = new ListNode(0);
22         dummy.next = head;
23         ListNode sorted = dummy.next; ListNode prev = dummy;
24         ListNode unsorted = head.next;
25         sorted.next = null;
26         while(unsorted != null){
27             while(sorted != null && sorted.val <= unsorted.val){
28                 prev = sorted;
29                 sorted = sorted.next;    
30             }  
31             ListNode temp = unsorted.next;
32             unsorted.next = sorted;
33             prev.next = unsorted;
34             
35             unsorted = temp;
36             
37             prev = dummy;
38             sorted = dummy.next;
39         }
40         return dummy.next;
41     }
42 }

 

posted @ 2017-10-13 11:47  Review->Improve  阅读(163)  评论(0编辑  收藏  举报