输入一个链表,输出该链表中倒数第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==nullptr)
{
return NULL;
}
k=k-1;
ListNode *p=pListHead;
ListNode *q=pListHead;
while(k!=0&&p->next!=nullptr)
{
p=p->next;
k--;
}
if(k!=0&&p->next==nullptr)
{
return NULL;
}
while(p->next!=nullptr)
{
p=p->next;
q=q->next;
}
return q;
}
};

本文介绍了一种高效算法,用于找到给定链表中倒数第K个节点。通过双指针技巧,避免了二次遍历,提高了算法效率。
572

被折叠的 条评论
为什么被折叠?



