题目描述
输入一个链表,输出该链表中倒数第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) {
auto p = pListHead, q = pListHead;
int i = 0;
for (; p != NULL; i++) {
if (i >= k){
q = q->next;
}
p = p->next;
}
if(i<k)
return NULL;
else
return q;
}
};
2、稍微复杂一点,先求出链表长度,如果链表长度比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) {
auto p = pListHead, q = pListHead;
unsigned int count=0;
for(; p != NULL; p = p->next){
count++;
}
if( count < k ){
return NULL;
}else{
unsigned int i = 0;
while( i < count-k){
q=q->next;
i++;
}
return q;
}
}
};