链表中倒数第k个结点
输入一个链表,输出该链表中倒数第k个结点。
分析
明显的快慢指针的问题
先让快指针走k步, 然后慢指针和快指针同时走, 当快指针到结尾之后, 慢指针即为第k个.
难点在于k的大小可能超过了链表长度, 此时fast指针会提前结束, 所以要在fast开始前进时进行判断:
while (fast != null && --k >= 0) {
fast = fast.next;
}
if (fast == null) return k == 0 ? slow : null;
代码
public class Solution {
public ListNode FindKthToTail(ListNode head,int k) {
if (head == null || k <= 0) return null;
ListNode fast = head, slow = head;
while (fast != null && --k >= 0) {
fast = fast.next;
}
if (fast == null) return k == 0 ? slow : null;
while (fast != null) {
fast = fast.next;
slow = slow.next;
}
return slow;
}
}