题解 | 链表中倒数最后k个结点

import java.util.*;

/*
 * public class ListNode {
 *   int val;
 *   ListNode next = null;
 *   public ListNode(int val) {
 *     this.val = val;
 *   }
 * }
 */

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param pHead ListNode类
     * @param k int整型
     * @return ListNode类
     * 空间复杂度O(1)的做法,使用快慢指针,双指针,两个指针相距k个位置,当后面的指针移动到队尾的时候
     * 第一个指针所指的位置,就是要求解的倒数第K的位置,就跟滑动窗口一样,很妙的搞法,一般要求空间复杂度为1的时候优先
     * 想到的就是快慢指针
     ** fast = 1, slow=1, posLeft = 0 
     ** fast = 2, slow=1, pos = 1 
     *  fast = 3, slow=1, pos=2
     *  fast = 4, slow =2, pos = 2
     *  fast = 5, slow =3, pos =2
     *  fast = null, slow =4, pos = 2
     */
    public ListNode FindKthToTail (ListNode pHead, int k) {
        if (k ==0 || pHead == null) {
            return null;
        }
        ListNode fast = pHead;
        ListNode slow = pHead;
        int posLeft = 0;
        while(fast != null) {
            if (posLeft < k) {
               posLeft++;
               fast = fast.next;
            } else {
               fast = fast.next;
               slow = slow.next;
            }
        }
        if (posLeft == k) {
            return slow;
        } else {
            return null;
        }
       
    }

    public ListNode FindKthToTailOn(ListNode pHead, int k) {
        if (k == 0) {
            return null;
        }
        List<ListNode> arr = new ArrayList<>();
        ListNode current = pHead;
        while (current != null) {
            arr.add(current);
            current = current.next;
        }
        if (k > arr.size()) {
            return null;
        }
        return arr.get(arr.size() - k);
    }
}

看到空间复杂度是O1,就需要联想到双指针的搞法

全部评论

相关推荐

榕城小榕树:1200单休,我去干点啥别的不好
点赞 评论 收藏
分享
Twilight_m...:表格简历有点难绷。说说个人看法: 1.个人基本情况里好多无意义信息,什么婚姻状况、健康状况、兴趣爱好、户口所在地、身份证号码、邮政编码,不知道的以为你填什么申请表呢。 2.校内实践个人认为对找工作几乎没帮助,建议换成和测开有关的项目,实在没得写留着也行。 3.工作经历完全看不出来是干什么的,起码看着和计算机没啥关系,建议加强描述,写点你在工作期间的实际产出、解决了什么问题。 4.个人简述大而空,看着像AI生成,感觉问题最大。“Python,C,C++成为我打造高效稳定服务的得力工具”、“我渴望凭借自身技术知识与创新能力,推动人工智能技术的应用发展,助力社会实现智能化转型”有种小学作文的美感。而且你确定你个人简述里写的你都会嘛?你AI这块写的什么“深入研究”,发几篇顶会的硕博生都不一定敢这么写。而且你AI这块的能力和软测也完全无关啊。个人简述建议写你对哪些技术栈、哪些语言、哪些生产工具的掌握,写的有条理些,而且最好是和测开强相关的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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