Sort a linked list using insertion sort.
这道题是要求用插入排序的方式对单链表进行排序。
先不考虑边界情况:
1. 将第一个结点看做有序区,之后的所有结点看做无序区。
2. 从第二个结点p开始,遍历有序区,知道遇到比结点p值大的结点q,将结点p插入到结点q之前。
3. 重复上述步骤直到链表遍历结束。
需要注意的是:
1. 遍历无序区时,需要保存当前结点的后继结点,以防指针丢失。
2. 若原链表为空,则直接返回NULL。
下面贴上代码:
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *insertionSortList(ListNode *head){
ListNode* first = new ListNode(0);
first->next = head;
if (head){
ListNode* p = head->next;
head->next = NULL;
while (p){
ListNode* r = p->next;
ListNode* q = first;
while (q->next&&q->next->val < p->val)
q = q->next;
p->next = q->next;
q->next = p;
p = r;
}
}
return first->next;
}
};
原文:http://blog.csdn.net/kaitankedemao/article/details/44498191