您的位置:首页 > 其它

输出链表中倒数第k个节点

2017-08-26 22:48 232 查看

题目描述

输入一个链表,输出该链表中倒数第k个结点。

struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};


算法的实现:快慢指针

ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
if(pListHead==NULL||k==0) return NULL;
ListNode *fast=NULL;
fast=pListHead;
ListNode *slow=NULL;
slow=pListHead;
for(int i=1;i<k;i++)//注意此处PListHeaD是头结点,需要移动K-1个,之间相差K
if(fast->next!=NULL)//注意此处快指针的next存在和不存在的情况
fast=fast->next;
else
return NULL;
while(fast->next!=NULL)
{
fast=fast->next;
slow=slow->next;
}
return slow;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: