剑指Offer 链表中倒数第k个结点

时间:2022-08-06 23:57:08

题目描述

输入一个链表,输出该链表中倒数第k个结点。
思路:
法1:设置2个指针p,q。p先移动k次,然后pq同时后移,p到链表尾尾的时候,q指向倒数第k个节点。
    注意://需要考虑k=0,以及List为空的情况
法2:利用栈,先全部压栈,pop k次,得到倒数第k个节点
AC代码:
 /*
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(k==||pListHead==NULL) //需要考虑k=0,以及List为空的情况
return NULL; ListNode *p,*q;
p=pListHead;
q=pListHead; for(int i=;i<k;i++) //注意边界值,从1开始
{
if(p->next!=NULL)
p=p->next;
else
return NULL;
} while(p->next!=NULL)
{
p=p->next;
q=q->next;
} return q; }
};