一.题目描述
输入一个链表,输出该链表中倒数第k个结点。
二.代码(C++)
/*
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* fast = pListHead,*slow = pListHead;
while(k--)
{
if(!fast)
return NULL;
fast = fast->next;
}
while(fast)
{
fast = fast->next;
slow = slow->next;
}
return slow;
}
};
三.提交记录
四.备注
设置快慢指针,快指针先走k步,再同步走,快指针到达结尾的时候慢指针指向目标元素。