【宫水三叶の剑指精选】一题三解 :「栈/队列」&「差值法」&「快慢指针」

链表中倒数最后k个结点

http://www.nowcoder.com/practice/886370fe658f41b498d40fb34ae76ff9

栈/队列 解法

一个使用额外空间的解法是利用栈(队列),将所有的节点压入占中栈(队列)中,令当前栈(队列)容量为

然后从栈顶(队列头)弹出 个( 个)元素,最后一个出栈(出队列)的元素即是答案。

代码(栈):

import java.util.*;

public class Solution {
    public ListNode FindKthToTail (ListNode head, int k) {
        Deque<ListNode> d = new ArrayDeque<>();
        while (head != null) {
            d.addLast(head);
            head = head.next;
        }
        if (d.size() < k) return null;
        ListNode ans = null;
        while (k-- > 0) ans = d.pollLast();
        return ans;
    }
}

代码(队列):

import java.util.*;

public class Solution {
    public ListNode FindKthToTail (ListNode head, int k) {
        Deque<ListNode> d = new ArrayDeque<>();
        while (head != null) {
            d.addLast(head);
            head = head.next;
        }
        if (d.size() < k) return null;
        k = d.size() - k + 1;
        ListNode ans = null;
        while (k-- > 0) ans = d.pollFirst();
        return ans;
    }
}
  • 时间复杂度:
  • 空间复杂度:

差值法

我们可以先对链表进行一次完整遍历,拿到总长度 ,最后由 即是倒数第 个节点距离 节点的距离。

代码:

import java.util.*;

public class Solution {
    public ListNode FindKthToTail (ListNode head, int k) {
        int cnt = 0;
        ListNode tmp = head;
        while (tmp != null && ++cnt > 0) tmp = tmp.next;
        if (cnt < k) return null;
        cnt -= k;
        while (cnt-- > 0) head = head.next;
        return head; 
    }
}
  • 时间复杂度:
  • 空间复杂度:

快慢指针

事实上,我们还可以使用「快慢指针」进行求解。

起始先让快指针 fast 先走 步,此时 fastslow 之间距离为 ,之后让 fastslow 指针一起走(始终维持相对距离为 ),当 fast 到达链表尾部,slow 即停在倒数第 个节点处。

代码:

import java.util.*;

public class Solution {
    public ListNode FindKthToTail (ListNode head, int k) {
        ListNode slow = head, fast = head;
        while (k-- > 0 && fast != null) fast = fast.next;
        if (k != -1) return null;
        while (fast != null) {
            slow = slow.next;
            fast = fast.next;
        }
        return slow;
    }
}
  • 时间复杂度:
  • 空间复杂度:

最后

这是我们「剑指 の 精选」系列文章的第 No.69 篇,系列开始于 2021/07/01。

该系列会将牛客网「剑指 Offer」中比较经典而又不过时的题目都讲一遍。

在提供追求「证明」&「思路」的同时,提供最为简洁的代码。

欢迎关注,交个朋友 (`・ω・´)

全部评论
快慢指针很妙
1 回复 分享
发布于 2022-02-16 22:40

相关推荐

不愿透露姓名的神秘牛友
2025-12-17 16:48
今天九点半到公司,我跟往常一样先扫了眼电脑,屁活儿没有。寻思着没事干,就去蹲了个厕所,回来摸出手机刷了会儿。结果老板刚好路过,拍了我一下说上班别玩手机,我吓得赶紧揣兜里。也就过了四十分钟吧,我的直属领导把我叫到小隔间,上来就给我一句:“你玩手机这事儿把老板惹毛了,说白了,你可以重新找工作了,等下&nbsp;HR&nbsp;会来跟你谈。”&nbsp;我当时脑子直接宕机,一句话都没憋出来。后面&nbsp;HR&nbsp;找我谈话,直属领导也在旁边。HR&nbsp;说我这毛病不是一次两次了,属于屡教不改,不光上班玩手机,还用公司电脑看论文、弄学校的事儿。我当时人都傻了,上班摸鱼是不对,可我都是闲得发慌的时候才摸啊!而且玩手机这事儿,从来没人跟我说过后果这么严重,更没人告诉我在公司学个习也算犯错!连一次口头提醒都没有,哪儿来的屡教不改啊?更让我膈应的是,昨天部门刚开了会,说四个实习生里留一个转正,让大家好好表现。结果今天我就因为玩手机被开了。但搞笑的是,开会前直属领导就把我叫去小会议室,明明白白告诉我:“转正这事儿你就别想了,你的学历达不到我们部门要求,当初招你进来也没打算给你这个机会。”合着我没入贵厂的眼是吧?可我都已经被排除在转正名单外了,摸个鱼至于直接把我开了吗?真的太离谱了!
rush$0522:转正名单没进,大概率本来就没打算留你
摸鱼被leader发现了...
点赞 评论 收藏
分享
2025-12-27 22:21
门头沟学院 Java
点赞 评论 收藏
分享
评论
4
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务