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

【链表问题】删除单链表中的第K个节点

前言 以专题的形式更新刷题贴,欢迎跟我一起学习刷题。每道题会提供简单的解答。 【题目描述】 在单链表中删除倒数第 K 个节点。...【要求】 如果链表的长度为 N, 时间复杂度达到 O(N), 额外空间复杂度达到 O(1) 【难度】 士 【解答】 删除的时候会出现三种情况: 1、不存在倒数第 K 个节点,此时不用删除。...2、倒数第 K 个节点就是第一个节点。 3、倒数第 K 个节点在第一个节点之后。 所以我们可以用一个变量 num 记录链表一共有多少个节点。 如果 num K,则属于第一种情况。...如果 num == K,则属于第二中情况。 如果 num > K, 则属于第三种情况,此时删除倒数第 K 个节点等价于删除第 (num - k + 1) 个节点。...)个节点 //定位到这个点的前驱 while (num - K !

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

    【链表问题】删除单链表的中间节点

    【题目描述】 给定链表的头节点head,实现删除链表的中间节点的函数。   ...N, 时间复杂度达到 O(N), 额外空间复杂度达到 O(1) 【难度】 士:★☆☆☆ 【解答】 这道题要求删除中间节点,我们可以采用双指针的方法来做,就是用一个快指针和一个慢指针,快指针每次前进两个节点...不过在做的时候,最好是先把一些特殊情况先处理好,例如删除的可能是第一个节点,也有可能不用删除节点(只有一个节点时就不用删除了。...个节点的题(【链表问题】删除单链表中的第K个节点) 其实也是可以使用双指针的,但个人认为,那道题使用双指针的方法并没有我上次那个做法优雅,而这次删除中间节点,则用双指针比较优雅。...问题拓展 题目:删除链表中 a / b 处的节点 【题目描述】   给定链表的头节点 head、整数 a 和 b,实现删除位于 a/b 处节点的函数。

    85940

    【链表问题】打卡9:将单链表的每K个节点之间逆序

    【题目描述】   给定一个单链表的头节点head, 实现一个调整单链表的函数,使得每K个节点之间逆序,如果最后不够K个节点一组,则不调整最后几个节点。   ...()的功能是将单链表的每K个节点之间逆序。...reverse()方法的功能是将一个单链表逆序。   那么对于下面的这个单链表,其中 K = 3。   ...我们把前K个节点与后面的节点分割出来:   temp指向的剩余的链表,可以说是原问题的一个子问题。我们可以调用reverseKNode()方法将temp指向的链表每K个节点之间进行逆序。...不过这种做法的额外空间复杂度是O(K)。   问题拓展   思考:如果这是一个环形单链表呢?该如何实现呢?

    50930

    【链表问题】打卡9:将单链表的每K个节点之间逆序

    【题目描述】 给定一个单链表的头节点head, 实现一个调整单链表的函数,使得每K个节点之间逆序,如果最后不够K个节点一组,则不调整最后几个节点。...【难度】 尉:★★☆☆ 【解答】 对于这道题,如果你不知道怎么逆序一个单链表,那么可以看一下我之前写的【链表问题】如何优雅着反转单链表 这道题我们可以用递归来实现,假设方法reverseKNode()的功能是将单链表的每...reverse()方法的功能是将一个单链表逆序。 那么对于下面的这个单链表,其中 K = 3。 ? 我们把前K个节点与后面的节点分割出来: ? temp指向的剩余的链表,可以说是原问题的一个子问题。...我们可以调用reverseKNode()方法将temp指向的链表每K个节点之间进行逆序。再调用reverse()方法把head指向的那3个节点进行逆序,结果如下: ?...,每K个节点入栈就把这K个节点出栈连接成一个链表,之后剩余再在进栈…..

    60150

    链表-----返回倒数第K个节点&&回文结构的判断&&相交链表

    1.返回倒数第K个节点 (1)返回链表的第k个节点,我们这里的做法是定义两个指针,这两个指针之间相差的是k这个长度;这个过程的实现就是让这两个指针都指向头部节点,让我们的快指针移动k个单位长度,慢指针原地不动...,这个过程我们是使用的k--进行循环的控制; (2)第二个while循环是进行的指针的移动,这个时候我们的快慢指针都已经在指定的位置,接下来进行的是两个指针的同时移动,最后循环结束的时候慢指针的下一个节点恰好就是我们要找到的倒数第...,返回false,如果循环的整个过程对应的位置都一样,就说明是回文结构,返回true. 3.相交链表的判断,返回交点 (1)两个链表的相交,肯定是中间的某个节点相交,最后的一个节点肯定是一样的,下面展示的就是我们的思路...因为在循环条件里面,我们的设置的循环条件是curA->next,当这个链表来到最后的一个节点,next节点就是空的,已经进不去循环了,所以相当于我们的最后一次的len并没有加上,如果我们想要得到这个链表的长度的精确值...(这个指定位置就是我们的gap--循环结束之后指向的位置)开始移动,找到对应的相交的节点,最后返回随便的一个,因为这个时候退出循环说明两个链表已经相交,这个时候长链表和短链表指向的都是我们要找的交点。

    2600

    【Leetcode】移除链表元素 链表的中间节点 链表中倒数第k个节点

    newhead ,同时为了省去找尾的麻烦,我们可以定义一个尾指针 tail 来保存尾节点; 2.再创建一个指针 cur =head ,用来遍历链表; 3.如果 cur->val !...= val ,则尾插 ,注意要判断 tail 是否为空 ,类似于单链表的尾插那部分,如果不理解的话,可查看文章 :单链表的增删查改; 4.如果 cur->val ==val,则 cur=cur->next...【Leetcode876】链表的中间节点 1.链接:链表的中间节点 2.题目再现 3.解法:快慢指针 1.定义一个快指针 fast 和一个慢指针 slow 都初始化为 head; 2.遍历链表,快指针一次走...} 三.链表中倒数第k个节点 1.链接:链表中倒数第k个节点 2.题目再现 3.解法 :快慢指针 1.定义一个快指针 fast 和一个慢指针 slow 都初始化为 head; 2.因为倒数第k个节点和尾节点的差为...每次只走1步; 注意,如果是k-1,那么遍历结束的条件是fast->next 是否为空 ,如果是k,那么遍历结束的条件是fast 是否为空; 4.返回慢指针。

    12310

    Leetcode链表回文 链表分割 链表相交 环形链表I 环形链表II 获取链表中倒数k的节点

    1.回文链表 要求:单链表来判断是否是回文串(正反相同),如果是返回true,不是返回false。...因为是单链表我们需要将中间点的后续节点翻转,从而由最后一个节点开始走知道slow的下一个节点指向slow,将slow下一个节点给到cur对象,让cur的下一个节点指向slow。...两个参数一个为链表,一个为x值,将链表中的每一个节点的值与x值比较,小的放在左边,大的放到右边,并且两者的相对位置不变 我们定义两个区间链表来获取小于x的节点和大于x的节点 当链表的节点走完后,将p1...=p2; return p1; } 3.链表相交 给两个单链表的头节点,让这两个链表相交,并返回相交的起始节点 求得两者的长度,因为知道了两者可能会相交,所以需要A和B同时走,然后相交...II 给定一个链表的头节点,如果有环则返回返回入环后的第一个节点,没有环则返回null 因为fast比slow要快一倍,当fast走了N圈后,如果有环,一定会和slow相遇。

    2300

    统计单链表中的节点数

    生活是不公平的,不管你的境遇如何,你只能全力以赴。 ?...最近学习Python感觉又回到了刚开始学习Python的现状,学着理论知识,做着笔记,这时应该要学会调整了,或者说是应该去找一些适量的题刷一下,便于记住一些简单的语法知识。...这里给大家推荐一个python刷题网站,叫Python123,切记刷题不是目的,得知道每次刷题后我又学到了什么。 今天分享一个C语言链表题目。 任务描述:本小节需要你统计单链表中的节点数。...任务如下: 编写程序,从键盘输入一串整数以及整数的个数,以单链表形式存储起来,计算单链表中结点的个数,输出单链表的数据及结点的个数。...printf("%d",p->data); p=p->next; } printf("\n"); } int Length(Node *phead){//统计节点

    1.2K30
    领券