《剑指offer》—— 14. 链表中倒数第k个结点(Java)

推荐

完整《剑指Offer》算法题解析系列请点击 👉 《剑指Offer》全解析 Java 版

 

题目描述

输入一个链表,输出该链表中倒数第k个结点。

/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class Solution {
    public ListNode FindKthToTail(ListNode head,int k) {

    }
}

 

思路:

链表,我们不知道长度,所以无法直接输出倒数第k个数。

(我下面说的位置,都是指针指向的位置。)

解法①
我们先遍历一边链表,获取链表长度 L 之后,得出倒数第k个数,是正数第 (L - K)个数。
然后我们再遍历到第 (L-K)个数输出就行了。

解法②
我们创建两个指针,一个快指针,一个慢指针。
快指针先走,走到第 k 个位置时候,慢指针也开始走。(此时快指针和慢指针之间距离一直是7)
当快指针走到最后一个点时,此时 快指针的位置就是 倒数第 k 个数。
因为,快慢指针之间的距离是k,快指针到了终点,那慢指针的位置就是倒数第k个位置。

 

解法①实现简单些,这里就不去实现了。

这里就实现下解法②:

/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class Solution {
    public ListNode FindKthToTail(ListNode head,int k) {
        if (head == null)
            return null;
        ListNode fast = head;
        while (fast != null && k-- > 0)
            fast = fast.next;
        if (k > 0)
            return null;
        ListNode low = head;
        while (fast != null){
            fast = fast.next;
            low = low.next;
        }
        return low;
    }
}

 

看完之后,如果还有什么不懂的,可以在评论区留言,会及时回答更新。

这里是猿兄,为你分享程序员的世界。

非常感谢各位大佬们能看到这里,如果觉得文章还不错的话, 求点赞👍 求关注💗 求分享👬求评论📝 这些对猿兄来说真的 非常有用!!!

注: 如果猿兄这篇博客有任何错误和建议,欢迎大家留言,不胜感激!

 

全部评论

相关推荐

不愿透露姓名的神秘牛友
06-26 14:50
人力小鱼姐:有后面墨迹那两句的时间问题早回答完了
点赞 评论 收藏
分享
06-15 02:05
已编辑
南昌航空大学 数据分析师
Eason三木:你如果想干技术岗,那几个发公众号合唱比赛的经历就去掉,优秀团员去掉,求职没用。然后CET4这种不是奖项,是技能,放到下面的专业技能里或者单独列一个英语能力。 另外好好改改你的排版,首行缩进完全没有必要,行间距好好调调,别让字和标题背景黏在一起,你下面说能做高质量PPT你得展现出来啊,你这简历排版我用PPT做的都能比你做的好。 然后自我评价,你如果要干数据工程师,抗压能力强最起码得有吧。
简历中的项目经历要怎么写
点赞 评论 收藏
分享
下北澤大天使:你是我见过最美的牛客女孩😍
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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