package com.wsq.linkedllisk;
public class MergeSortList {
public ListNode sortList(ListNode head) {
return sortList(head, null);
}
private ListNode sortList(ListNode head, Object tail) {
if(head == null) {
return head;
}
if(head.next == tail) {
head.next = null;
return head;
}
ListNode slow = head;
ListNode fast = head;
while(fast != tail) {
slow = slow.next;
fast = fast.next;
if(fast != tail) {
fast = fast.next;
}
}
ListNode mid = slow;
ListNode leftList = sortList(head, mid);
ListNode rightList = sortList(mid, tail);
return merge(leftList, rightList);
}
private ListNode merge(ListNode leftList, ListNode rightList) {
ListNode head = new ListNode(0);
ListNode tmp1 = leftList;
ListNode tmp2 = rightList;
ListNode node = head;
while(tmp1 != null && tmp2 != null) {
if(tmp1.val <= tmp2.val) {
node.next = tmp1;
tmp1 = tmp1.next;
}else {
node.next = tmp2;
tmp2 = tmp2.next;
}
node = node.next;
}
if(tmp1 != null) {
node.next = tmp1;
}else {
node.next = tmp2;
}
return head.next;
}
}