题目描述
输入一个链表,输出该链表中倒数第k个结点。
思路一:先算是第几个节点
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
/*
* 思路一:查出链表的长度,算出是第len-k个节点,注意区分当len-k大于等于小于0时候的情况
*/
class Solution {
public:
ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
ListNode* p = NULL;
p = pListHead;
int length = 0;
while(p != NULL){
length++;
p = p->next;
}
p = pListHead;
length = length - k;
if(length < 0) return NULL;
while(length>0){
pListHead = pListHead->next;
length--;
}
return pListHead;
}
};
思路二:有人领跑k-1个节点,一步到位
/*
* 思路二:设置两个指针,一个先走k-1步,然后第二个跟着一起跑,当第一个指针先到最后一个节点的时候,第二个指针刚好指向倒数第k个节点
* 如果还不到k-1步,第一个指针就已经达到最后一个节点的话,返回NULL,
* 注意链表为空和k<0的边界条件
*
*/
class Solution {
public:
ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
if(pListHead == NULL || k <0 ){
return NULL;
}
ListNode* pre = pListHead;
ListNode* p = pListHead;
int prek = k;
while(--prek){
if(pre->next == NULL){
return NULL;
}else{
pre = pre->next;
}
}
while(pre->next != NULL){
p = p->next;
pre = pre->next;
}
return p;
}
};