[LeetCode]Insertion Sort

来源:互联网 发布:中文编程安卓版 编辑:程序博客网 时间:2024/06/07 07:01

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;    }};
0 0
原创粉丝点击