《剑指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;
    }
}

 

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

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

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

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

 

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务