【剑指offer】链表中的倒数第k个结点

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

分析:

定义两个结点p1和p2都指向头节点,p1先走k-1步,然后p1和p2一起走,当p1走到链表尾部时,p2指向的结点就是倒数第k个结点

遍历一遍链表即可,时间复杂度O(N)

复制代码
ListNode* FindKthToTail(ListNode* pListHead, unsigned int k)
{
    if(pListHead==NULL||k==0)
        return NULL;

    ListNode *p1,*p2;
    p1=pListHead;
    p2=pListHead;
    
    //先走k-1步
    int x=k-1;
    while(x&&p1!=NULL)
    {
        p1=p1->next;
        x--;
    }
    if(p1==NULL)
        return NULL;
    
    //一起走,当p1走到末尾时,p2指向的结点就是倒数第k个结点
    while(p1->next!=NULL)
    {
        p2=p2->next;
        p1=p1->next;
    }
    return p2;
}
复制代码



posted @   西*风  阅读(134)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
点击右上角即可分享
微信分享提示