《剑指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;
}
}
看完之后,如果还有什么不懂的,可以在评论区留言,会及时回答更新。
这里是猿兄,为你分享程序员的世界。
非常感谢各位大佬们能看到这里,如果觉得文章还不错的话, 求点赞👍 求关注💗 求分享👬求评论📝 这些对猿兄来说真的 非常有用!!!
注: 如果猿兄这篇博客有任何错误和建议,欢迎大家留言,不胜感激!