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

提建议就是,有些题还是有联系的,建议就收看完 876.链表的中间节点(http://t.csdnimg.cn/7axLa,再将这一题联系起来


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

题目:

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

说明:

给定的 k 保证是有效的。

题目链接

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

文字 和 画图 分析

这题和快慢指针有点像(返回 876.链表的中间节点),我们定义两个指针 fast指针 和 slow指针,都存放头节点的地址

这里我们有两种思路:

  1. fast 先比 slow 多走 k 步,然后同时走完链表(放循环里面)
  2. fast 先比 slow 多走 k - 1 步,然后同时走完链表(放循环里面)

第一种思路:

结束条件:

fast ==NULL

第二种思路:

结束条件:

fast->next == NULL

代码

代码一(思路一):

int kthToLast(struct ListNode* head, int k)
{
    struct ListNode*slow = head;
    struct ListNode*fast = head;
    while(k--)
    {
        fast = fast->next;
    }
   while(fast)
   {
       fast = fast->next;
       slow = slow->next;
   }
    return slow->val;
}

 代码二(思路二):

int kthToLast(struct ListNode* head, int k)
{
    struct ListNode*slow = head;
    struct ListNode*fast = head;
    while(--k)
    {
        fast = fast->next;
    }
   while(fast->next)
   {
       fast = fast->next;
       slow = slow->next;
   }
    return slow->val;
}

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-09 02:00:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-09 02:00:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-09 02:00:02       82 阅读
  4. Python语言-面向对象

    2023-12-09 02:00:02       91 阅读

热门阅读

  1. QT 中 线程池 (备查)

    2023-12-09 02:00:02       67 阅读
  2. Copilot使用指南:提升编程效率的智能助手

    2023-12-09 02:00:02       89 阅读
  3. NTP时钟同步服务器(校时服务器)技术参数分享

    2023-12-09 02:00:02       52 阅读
  4. v-model和:model的区别

    2023-12-09 02:00:02       54 阅读
  5. Ubuntu22.04安装Mariadb

    2023-12-09 02:00:02       66 阅读
  6. Ubuntu18.04 Udacity project_10_MPC_control 如何运行

    2023-12-09 02:00:02       64 阅读
  7. C#多进程通信之共享内存方式

    2023-12-09 02:00:02       55 阅读
  8. qt day2

    qt day2

    2023-12-09 02:00:02      55 阅读