问题描述:
输入一个链表,输出该链表中倒数第k个结点。
源码:
一定要考虑链表长度不足k的情况。
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
if(!pListHead || k==0) return nullptr;
ListNode *begin=pListHead, *end=pListHead;
while(k--){
if(end) end = end->next;
else return nullptr;
}
while(end){
begin = begin->next;
end = end->next;
}
return begin;
}
};