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

本文详细介绍了链表的插入排序算法实现,通过lastsorted和cur指针管理已排序和未排序部分,确保链表有序。当遇到需要插入的节点时,使用findlocation和sup指针找到合适位置,保持链表有序。代码清晰地展示了这一过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目概述

在这里插入图片描述

思路

  思路很简单,与数组的插入排序类似,使用一个lastsortedlastsortedlastsorted指针表示已经被排到有序的部分链表的尾结点的指针,使用curcurcur指针来指向当前正在检查的节点,如果cur−>valcur->valcur>val大于等于lastsorted−>vallastsorted->vallastsorted>val,那么直接把cur指的值插入到我们的有序链表中就行,也就是让lastsorted=lastsorted−>next;cur=lastsorted−>next;lastsorted = lastsorted->next; cur = lastsorted->next;lastsorted=lastsorted>next;cur=lastsorted>next;如果cur−>valcur->valcur>val小于lastsorted−>vallastsorted->vallastsorted>val那么就用findlocationfindlocationfindlocation指针和supsupsup指针来从头开始找到合适的位置进行一个结点的插入,为了让cur能回到下一个结点,同时也相当于把curcurcur目前所指结点从lastsortedlastsortedlastsortednextnextnext卸下来,让lastsorted−>next=cur−>nextlastsorted->next = cur->nextlastsorted>next=cur>next,这样存储好curcurcur本来的nextnextnext.
代码:

class Solution {
public:
    ListNode* insertionSortList(ListNode* head) 
    {
        if (head == nullptr || head->next == nullptr)
        {
            return head;
        }
        ListNode* cur = head->next;
        ListNode* dummyhead = new ListNode(0, head);
        ListNode* lastsorted = head;
        while (cur != nullptr)
        {
            if (cur->val >= lastsorted->val)
            {
                lastsorted = lastsorted->next;
            }
            else
            {
                lastsorted->next = cur->next;
                ListNode* findlocation = dummyhead->next;
                ListNode* prevsup = dummyhead;
                while (findlocation->val < cur->val)
                {
                    findlocation = findlocation->next;
                    prevsup = prevsup->next;
                }
                prevsup->next = cur;
                cur->next = findlocation;
            }
            cur = lastsorted->next;
        }
        ListNode* ret = dummyhead->next;
        delete dummyhead;
        return ret;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值