LeetCode 147. 对链表进行插入排序

对链表进行插入排序。

插入排序的动画演示如上。从第一个元素开始,该链表可以被认为已经部分排序(用黑色表示)。
每次迭代时,从输入数据中移除一个元素(用红色表示),并原地将其插入到已排好序的链表中。

 

插入排序算法:

    插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。
    每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其插入。
    重复直到所有输入数据插入完为止。

 

示例 1:

输入: 4->2->1->3
输出: 1->2->3->4

示例 2:

输入: -1->5->3->4->0
输出: -1->0->3->4->5
算法:我们依据插入排序的思路来处理。每次将新链表从表头开始与原链表的数进行比较,直到找到第一个大于其元素的前驱结点,然后插入即可。

/**
 * 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) {
        if(!head||!head->next)return head;
        auto l=new ListNode(-1);
        auto p=l;
        auto cur=head;
        while(cur){
            auto q=cur->next;
            p=l;
            while(p->next&&p->next->val<=cur->val)p=p->next;
            cur->next=p->next;
            p->next=cur;
            cur=q;
        }
        return l->next;
    }
};

 

posted @ 2019-07-10 10:05  YF-1994  阅读(184)  评论(0编辑  收藏  举报