ACM-单向链表插入排序算法(在原链表上操作)

本文详细解析了一种链表插入排序算法的实现过程。首先处理链表的特殊情况,如链表为空或仅有一个节点的情况;然后通过比较链表的前两个节点进行初步排序,并断开连接形成两个链表部分;最后,逐一将未排序节点插入已排序链表中,通过三种情况的判断完成整个链表的排序。
/*
1.若链表只有一个节点或者为空,直接返回
2.将链表的前两个节点排序,并将排序之后的第二个节点的下一个节点赋空
3.此时整个链表分为了两个,将未排序的节点一一插入到已排序链表中:
  3.1.第一种情况,待插入节点比排序链表的头节点小
  3.2.第二种情况,待插入节点比排序链表的最后节点大
  3.3.第三种情况,待插入节点可插入到排序链表中
*/
 
class Solution {
public:
    ListNode *insertionSortList(ListNode *head) {
        //输入为空或者只有一个节点
        if(!head || !head->next)return head;
        ListNode *unSortCur = head->next->next;
        if(head->val > head->next->val)
        {
            ListNode *p = head;
            head = head->next;
            head->next = p;
            p->next = nullptr;
        }
        else
            head->next->next = nullptr;
        while(unSortCur != nullptr) //QQQ
        {
            ListNode *sortPre = head;
            ListNode *sortCur = sortPre->next;
            ListNode *unSortNext = unSortCur->next;
            if(unSortCur->val < head->val)
            {
                unSortCur->next = head;
                head = unSortCur;
            }
            else{
                while(sortCur != nullptr && unSortCur->val > sortCur->val)
                {
                    sortCur = sortCur->next;
                    sortPre = sortPre->next;
                }
                if(sortCur == nullptr){
                    sortPre->next = unSortCur;
                    unSortCur->next = nullptr;
                }
                else{
                    sortPre->next = unSortCur;
                    unSortCur->next = sortCur;
                }
            }
            unSortCur = unSortNext;
        }
        return head;
    }
};

 

转载于:https://www.cnblogs.com/qiang-wei/p/9486121.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值