LeetCode 面试题 02.02. 返回倒数第 k 个节点

面试题 02.02. 返回倒数第 k 个节点

题目链接:面试题 02.02. 返回倒数第 k 个节点

题目描述:实现一种算法,找出单向链表中倒数第 k 个节点。返回该节点的值。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
 typedef struct ListNode ListNode;
int kthToLast(struct ListNode* head, int k) 
{
    //创建快慢指针
    ListNode* slow = head;
    ListNode* fast = head;

    //快指针先走k个结点
    while(k--)
    {
        fast = fast->next;
    }

    while(fast)
    {
        slow = slow->next;
        fast = fast->next;
    }
    return slow->val;
}

解题思路:

解决这个问题的核心思想是:通过在两个指针之间制造并保持一个固定的距离差,当一个指针到达终点时,另一个指针就正好在我们想要的位置上。

想象一下两个指针在一个链表上移动:

  1. 我们想找到距离终点 k 的位置。
  2. 我们先让指针 A(我们称之为 fast 指针)从起点出发,先走 k 步。
  3. 然后,让指针 B(我们称之为 slow 指针)也从起点出发。
  4. 现在,A 和 B 同时以相同的速度(每次一步)向前走。
  5. 因为 A 和 B 之间始终保持着 k 步的距离差,所以当 A 到达终点时,B 所在的位置,正好就是距离终点 k 步的地方。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值