首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Leetcode -147.对链表进行插入排序 -237.删除链表中的节点】

Leetcode -147.对链表进行插入排序 题目: 给定单个链表的头 head ,使用 插入排序 对链表进行排序,并返回 排序后链表的头 。...sorttail当前还不是val最大的节点,这时候就更新sorttail即可;要么就说明还没排序好,这时候就定义一个指针prev,prev从哨兵位开始,prev找到比cur的val大的节点的上一个节点,...改变它们的相对位置,还要保持原链表的相对位置不变; 假设链表的值为:5->3->1->4->2->NULL 第一次迭代: 第一次迭代排序好的链表: 第二次迭代: 第二次迭代排序好的链表...: 第三次迭代: 第三次迭代排序好的链表: 第四次迭代: 第四次迭代排序好的链表,此时cur为空,循环结束: 代码和注释: struct ListNode* insertionSortList...给你一个需要删除的节点 node 。你将 无法访问 第一个节点 head。 链表的所有值都是 唯一的,并且保证给定的节点 node 不是链表中的最后一个节点。 删除给定的节点。

8910
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    对链表进行插入排序(链表)

    题目 对链表进行插入排序。 ? 插入排序的动画演示如上。从第一个元素开始,该链表可以被认为已经部分排序(用黑色表示)。...每次迭代时,从输入数据中移除一个元素(用红色表示),并原地将其插入到已排好序的链表中。 插入排序算法: 插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。...每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其插入。 重复直到所有输入数据插入完为止。...解题 2.1 multimap 取巧做法 利用map的有序性,把节点指针存进去 class Solution { public: ListNode* insertionSortList(ListNode...if(cur->val >= tail->val)//大于已排序的结尾,直接接上尾巴 { tail->next = cur;

    48710

    Leetcode No.147 对链表进行插入排序

    一、题目描述 对链表进行插入排序。 给定单链表的头指针,使用插入排序对链表进行排序,然后返回已排序链表的头指针。 从第一个元素开始,该链表可以被认为已经部分排序。...对于单向链表而言,只有指向后一个节点的指针,因此需要从链表的头节点开始往后遍历链表中的节点,寻找插入位置。 对链表进行插入排序的具体过程如下。 1....首先判断给定的链表是否为空,若为空,则不需要进行排序,直接返回。 2. 创建哑节点 dummyHead,令 dummyHead.next = head。...引入哑节点是为了便于在 head 节点之前插入节点。 3. 维护 lastSorted 为链表的已排序部分的最后一个节点,初始时 lastSorted = head。 4....返回 dummyHead.next,为排序后的链表的头节点。

    30720

    ​LeetCode刷题实战147:对链表进行插入排序

    今天和大家聊的问题叫做 对链表进行插入排序,我们先来看题面: https://leetcode-cn.com/problems/insertion-sort-list/ Sort a linked list...题意 对链表进行插入排序。 ? 插入排序的动画演示如上。从第一个元素开始,该链表可以被认为已经部分排序(用黑色表示)。...每次迭代时,从输入数据中移除一个元素(用红色表示),并原地将其插入到已排好序的链表中。 插入排序算法: 插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。...,和数组的插入排序一样,只不过是链表而已,这里用的都是单向链表,涉及到以下操作: 1....2. left,right分别为已排序链表的最左端结点,和最右端结点,初始时刻,left=head,right=head->next。如果这个两个结点逆序,利用操作1交换它们。 3.

    23420

    每日一题2-对链表进行插入排序

    对链表进行插入排序 对链表进行插入排序 示例 1: 输入: 4->2->1->3 输出: 1->2->3->4 示例 2: 输入: -1->5->3->4->0 输出: -1->0->3->4->5...i 文字描述: 遍历链表,第一个元素默认是有序的 在遍历过程中 记录, 有序链表 开始位置: 是否固定下来 ?...head ; } //01 构造带头节点的单链表,默认第一个节点有序 ListNode start(0);//保持头节点不变是为了插入方面,也可以不要...,每次寻找pre节点时候 判断一下是否null start.next=head; ListNode* end=head; //有序链表结束位置,end也是遍历的迭代器...* pre = NULL;//插入排序需要插入记录位置,每次都需要重新计算 //从第一个元素开始遍历链表,假设第一个元素是有序的 while(cur) {

    56620

    删除链表的节点

    删除链表的节点 18.删除链表的节点 描述 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。...1.此题对比原题有改动 2.题目保证链表中节点的值互不相同 3.该题只会输出返回的链表和结果做对比,所以若使用 C 或 C++ 语言,你不需要 free 或 delete 被删除的节点 数据范围: 0...链表节点值<=10000 0链表长度<=10000 思路:指针跳过要删除的节点,考虑特殊节点情况即可 /** * struct ListNode { * int val;...: val(x), next(nullptr) {} * }; */ class Solution { public: /** * 代码中的类名...、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param head ListNode类 * @param val int整型

    1K10

    对链表进行插入排序

    对链表进行插入排序。 ? 插入排序的动画演示如上。从第一个元素开始,该链表可以被认为已经部分排序(用黑色表示)。...每次迭代时,从输入数据中移除一个元素(用红色表示),并原地将其插入到已排好序的链表中。 插入排序算法: 插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。...每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其插入。 重复直到所有输入数据插入完为止。...提前用dummy记录,然后利用pre对dummy第一层的操作可以让dummy一直指向最前面的牌。...类似于交换链表 class Solution: def insertionSortList(self, head: ListNode) -> ListNode: dummy =

    29120

    C语言每日一题(60)对链表进行插入排序

    题目链接 力扣网 147 对链表进行插入排序 题目描述 给定单个链表的头 head ,使用 插入排序 对链表进行排序,并返回 排序后链表的头 。...对链表进行插入排序。...[1, 5000]范围内 -5000 <= Node.val <= 5000 思路分析 知识点:链表、插入排序 解析: 设置一个哨兵位,方便我们进行插入,接下来说明一下需要定义的指针变量 1.lastsorted...:指向待插入链表的最后一个位置的指针(插入排序将插入位置前面的部分看成是已经有序的),最开始指向head。...小于的话,prev指针从dummy开始遍历,找到需要插入的结点的前一个结点进行插入操作 链表的插入操作:将lastsorted指针的next指向cur的next,cur的next指向prev的next,

    9410

    对链表进行插入排序 算法解析

    一、题目 1、算法题目 “给定一个链表的头,使用插入排序对链表进行排序,返回排序后链表的头。” 题目链接: 来源:力扣(LeetCode) 链接: 147....对链表进行插入排序 - 力扣(LeetCode) 2、题目描述 给定单个链表的头 head ,使用 插入排序 对链表进行排序,并返回 排序后链表的头 。...下面是插入排序算法的一个图形示例。部分排序的列表(黑色)最初只包含列表中的第一个元素。每次迭代时,从输入数据中删除一个元素(红色),并就地插入已排序的列表中。 对链表进行插入排序。...对于链表来说,就是遍历链表找到要插入的位置,更新相邻接点的指针即可。...空间复杂度:O(1) 只需要常量级的变量空间。 三、总结 对于链表来说,插入元素时只需要更新相邻节点的指针即可,不用像数组插入元素要移动元素的位置。 所以链表的插入操作的时间复杂度是O(1)。

    30110

    leetcode链表之删除链表的节点

    序 本文主要记录一下leetcode链表之删除链表的节点 题目 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。 返回删除后的链表的头节点。...注意:此题对比原题有改动 示例 1: 输入: head = [4,5,1,9], val = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为...示例 2: 输入: head = [4,5,1,9], val = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 ->...说明: 题目保证链表中节点的值互不相同 若使用 C 或 C++ 语言,你不需要 free 或 delete 被删除的节点 来源:力扣(LeetCode) 链接:https://leetcode-cn.com...preNode指针维护前一个节点,好进行删除操作 doc shan-chu-lian-biao-de-jie-dian-lcof

    63020

    动画:删除链表的节点

    题目汇总链接:https://www.algomooc.com/hi-offer 一、题目描述 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。 返回删除后的链表的头节点。...说明: 题目保证链表中节点的值互不相同 若使用 C 或 C++ 语言,你不需要 free 或 delete 被删除的节点 二、题目解析 我们依旧用 四步分析法 进行结构化的分析。...删除链表的节点的副本.004 定位到目标节点后,需要修改这个节点,题目的要求是删除,对于链表中的每个节点来说,它都有前驱和后继两个节点,那么删除操作就很简单了:设节点 cur 的前驱节点为 pre ,后继节点为...删除链表的节点.005 2、规律 链表的删除操作一般都是使用双指针。 3、匹配 双指针。 4、边界 删除的节点是头节点 三、动画描述 四、图片描述 面试题18. 删除链表的节点.002 面试题18....删除链表的节点.003 面试题18. 删除链表的节点.004 面试题18. 删除链表的节点.005 面试题18. 删除链表的节点.006 面试题18. 删除链表的节点.007 面试题18.

    1.2K40

    删除链表中的节点

    题目描述 难度级别:简单 请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点。传入函数的唯一参数为 要被删除的节点 。...示例 2: 输入:head = [4,5,1,9], node = 1 输出:[4,5,9] 解释:给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9....提示: 链表至少包含两个节点。 链表中所有节点的值都是唯一的。 给定的节点为非末尾节点并且一定是链表中的一个有效节点。 不要从你的函数中返回任何结果。...解题思路 题目中待传递给当前函数的实参node,它是链表中的某一个待删除的节点,然后从链表中删除这个节点。...这里因为待传入的实参没有完整的链表,所以无法获取到之前节点,所以无法修改前一个节点的next指向。这时需要的是将要删除节点的值替换为它的下一个节点的值,之后要删除这个节点的next指向为下下一项。

    2.4K00

    1 链表的中间节点

    1 Leetcode876 链表的中间节点 给定一个带有头结点 head 的非空单链表,返回链表的中间结点。 如果有两个中间结点,则返回第二个中间结点。...输入:[1,2,3,4,5] 输出:此列表中的结点 3 (序列化形式:[3,4,5]) 返回的结点值为 3 。 (测评系统对该结点序列化表述是 [3,4,5])。...01 题目解析 链表简述 说到链表,难免会想到数组,数组的内存地址空间连续,查找速度快(O(1)),但是插入和删除会因为大量移动元素导致效率不高,所以引入了链表结构。...链表中内存低地址不连续,通过"指针"将零散的地址链接在一起,如下图(单链表)所示。 ?...解题思路(快慢指针) 题中需要返回中间节点,我们使用两个指针p,q,p指针一次往前走两步,q指针一次走一步,当快指针p到达末尾也就是NULL的时候,p所指向的就是中间节点。我们看一下动画!

    49010

    使用 Python 对波形中的数组进行排序

    在本文中,我们将学习一个 python 程序来对波形中的数组进行排序。 假设我们采用了一个未排序的输入数组。我们现在将对波形中的输入数组进行排序。...− 创建一个函数,通过接受输入数组和数组长度作为参数来对波形中的数组进行排序。 使用 sort() 函数(按升序/降序对列表进行排序)按升序对输入数组进行排序。...例 以下程序使用 python 内置 sort() 函数对波形中的输入数组进行排序 − # creating a function to sort the array in waveform by accepting...例 以下程序仅使用一个 for 循环且不带内置函数以波形对输入数组进行排序 - # creating a function to sort the array in waveform by accepting...结论 在本文中,我们学习了如何使用两种不同的方法对给定的波形阵列进行排序。与第一种方法相比,O(log N)时间复杂度降低的新逻辑是我们用来降低时间复杂度的逻辑。

    6.9K50

    常用链表排序算法_单链表的排序算法

    tail->next 图10:有N个节点的链表选择排序 1、先在原链表中找最小的,找到一个后就把它放到另一个空的链表中; 2、空链表中安放第一个进来的节点,产生一个有序链表,并且让它在原链表中分离出来...按照这种思想,依次 对链表从头到尾执行一遍,就可以使无序链表变为有序链表。...2、从图12链表中取节点,到图11链表中定位插入。 3、上面图示虽说画了两条链表,其实只有一条链表。在排序中,实质只增加了一个用于指向剩下需要排序节点的头指针first罢了。...注意:按道理来说,这句话可以放到下面注释了的那个位置也应该对的,但是就是不能。...(由小到大) 返回:指向链表表头的指针 ========================== */ /* 直接插入排序的基本思想就是对当前还未排好序的范围内的全部节点, 自上而下对相邻的两个节点依次进行比较和调整

    61420
    领券