原题描述:
输入一个链表,输出该链表中倒数第k个结点。
思路:
设两个指针,开始时都指向头结点。一个指针先从头结点移动到第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) {
ListNode*p=pListHead;
ListNode*r=pListHead;
if(p==NULL) return NULL;
int iter=k-1;
while(iter--){
p=p->next;
if(p==NULL) return NULL;
}
while(p->next!=NULL){
r=r->next;
p=p->next;
}
return r;
}
};