题目: 插入排序的动画演示如上。从第一个元素开始,该链表可以被认为已经部分排序(用黑色表示)。
每次迭代时,从输入数据中移除一个元素(用红色表示),并原地将其插入到已排好序的链表中
插入排序算法:
- 插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。
- 每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其插入。
- 重复直到所有输入数据插入完为止
示例:
方法一:从前往后找插入点
class Solution {
public ListNode insertionSortList(ListNode head) {
if(head==null)return head;
ListNode pre=head,cur=head.next,tmp_cur,tmp_pre=null,tmp;
while(cur!=null) {
if(cur.val<pre.val) {
tmp_cur=head;
tmp=cur.next;
while(tmp_cur.val<cur.val) {
tmp_pre=tmp_cur;
tmp_cur=tmp_cur.next;
}
if(tmp_cur!=head) {
tmp_pre.next=cur;
cur.next=tmp_cur;
}else {
cur.next=head;
head=cur;
}
cur=tmp;
pre.next=cur;
continue;
}
pre=cur;
cur=cur.next;
}
return head;
}
方法一的优化:
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode insertionSortList(ListNode head) {
if(head==null)return head;
ListNode lastSorted=head,nilhead=new ListNode(0),cur=head;
nilhead.next=head;
while(cur!=null) {
if(lastSorted.val<=cur.val) {
lastSorted=cur;
}else {
ListNode pre=nilhead;
while(pre.next.val<=cur.val) {
pre=pre.next;
}
lastSorted.next=cur.next;
cur.next=pre.next;
pre.next=cur;
}
cur=lastSorted.next;
}
return nilhead.next;
}
}