版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/xiangxianghehe/article/details/88829716
牛客网链接:链表的倒数第k个节点
题目:
输入一个链表,输出该链表中倒数第k个结点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾结点是倒数第1个结点。例如一个链表有6个结点,从头结点开始它们的值依次是1、2、3、4、5、6。这个链表的倒数第3个结点是值为4的结点。
思路:
为了能够只遍历一次就能找到倒数第k个节点,可以定义两个指针:
- 第一个指针从链表的头指针开始遍历向前走k-1,第二个指针保持不动;
- 从第k步开始,第二个指针也开始从链表的头指针开始遍历;
- 由于两个指针的距离保持在k-1,当第一个(走在前面的)指针到达链表的尾结点时,第二个指针(走在后面的)指针正好是倒数第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 || k == 0) return nullptr;
ListNode* aHead = pListHead;
ListNode* bHead = pListHead;
while(k>1)
{
if(aHead->next!=nullptr)
aHead = aHead->next;
else
return nullptr;
k--;
}
while(aHead->next!=nullptr)
{
bHead = bHead->next;
aHead = aHead->next;
}
return bHead;
}
};