剑指 Offer 22. 链表中倒数第k个节点

题目

在这里插入图片描述

思路(快慢指针)

在链表中要熟用双指针,对于这种求倒数第k个节点的是链表中很经典的问题
通常可以让快指针先走k步(保证快慢指针中间相差k步),然后快、慢指针在一起以每次走1步一起走,直到快指针指向NULL,此时慢指针指向的就是倒数第K个节点
在这里插入图片描述

代码实现

struct ListNode* getKthFromEnd(struct ListNode* head, int k){
     if (0 == k) return NULL;
    struct ListNode* fast, *slow;
    fast = slow = head;
    //快指针先走K步
    while (k--)
    {
        //判断是否存在倒数第k个元素
        if (fast == NULL) return NULL;
        fast = fast->next;
    }
    //快慢指针同时走,直到快指针下一个位置为空
    while (fast)
    {
        fast = fast->next;
        slow = slow->next;
    }
    return slow;
}

在这里插入图片描述

总结

快慢指针是一种常用的链表指针操作技巧,可以在链表中解决很多问题。下面是一些可以使用快慢指针的常见场景:

  1. 判断链表是否有环:快慢指针可以用来判断一个链表是否有环。将慢指针移动一步,快指针移动两步,如果存在环,两个指针最终会相遇。这个技巧被称为快慢指针法或者龟兔赛跑算法。

  2. 查找链表的中间节点:使用快慢指针可以查找链表的中间节点。将慢指针移动一步,快指针移动两步,当快指针到达链表末尾时,慢指针刚好在链表中间。

  3. 链表倒数第k个节点:使用快慢指针也可以查找链表的倒数第k个节点。将快指针移动k-1步,然后将快慢指针一起移动,当快指针到达链表末尾时,慢指针所指的节点就是倒数第k个节点。

  4. 删除链表的倒数第n个节点:可以使用快慢指针删除链表的倒数第n个节点。先将快指针移动n步,然后将快慢指针一起移动,当快指针到达链表末尾时,慢指针所指的节点就是要删除的节点。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值