题目
输入一个链表,输出该链表中倒数第k个结点。
思路
- 思路一
- 思路二
- 用两个指针,初始都指向链表头部。
- 指针1走k-1步到达正向第k个结点处。
- 两个指针同时往后走,当指针1到达最后一个节点的时候,指针2即为倒数第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 nullptr;
ListNode* p = pListHead; // 用来计算链表的长度
ListNode* resNode = pListHead; // 返回值,倒数第K个结点。
int n = 1;
while ( p->next != nullptr ) {
++n;
p = p->next;
}
if ( k > n ) return nullptr;
// 要找的结点是第n-k+1个结点,第1个结点到第n-k+1个结点要走k-n步。
int dis = n - k;
while ( dis != 0 ) {
resNode = resNode->next;
--dis;
}
return resNode;
}
};
思路二代码
/*
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 nullptr;
ListNode* p = pListHead;
ListNode* resNode = pListHead;
while ( --k && p != nullptr )
p = p->next;
if ( !p ) return nullptr;
while ( p -> next != nullptr ) {
p = p->next;
resNode = resNode->next;
}
return resNode;
}
};