剑指offer面试题22:链表中倒数第k个节点

面试题22:链表中倒数第k个节点

题目:

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

示例:

复制代码
输入: 1->2->3->4->5 和 k = 2
输出: 4

思路:

1、求倒数第k个节点的值,我们归纳出当总共有n个节点时,倒数第k个节点就相当于从头开始的第n-k+1个节点。此方式要遍历两次链表第一次求出链表总数,第二次才能解出倒数第k个节点。

2、我们还可以设置两个指针都同时指向头结点,第一个指针先走k-1步然后第二个指针开始跟第一个指针一起向后遍历,当第一个指针遍历到最后一个元素时,第二个指针就是指向的倒数第k个节点。

代码:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    int kthToLast(ListNode* head, int k) {
        if(head==NULL||k==0)
            return NULL;
        ListNode* first_index  = head;
        ListNode* second_index = head;

        for(int i=0;i<k-1;i++){
            if(first_index->next==NULL)
                return NULL;
            first_index = first_index->next;
        }

        while(first_index->next!=NULL){
            first_index = first_index->next;
            second_index = second_index->next;
        }

        return second_index->val;
    }
};

注:

以下情况会导致代码崩溃,需要考虑

  1. 输入head为空指针。
  2. 输入head为头节点的链表的节点总数少于k。
  3. 输入参数k为0。由于k是无符号整数,在for循环中k-1将得到4294967295。

考点:

1.考察链表的理解

2.考察所写代码的鲁棒性

相关推荐
浅念-24 分钟前
「一文吃透 BFS:从层序遍历到锯齿形、最大宽度、每层最大值」
数据结构·算法
苍煜3 小时前
二叉树、红黑树、B树、B+树通俗教学:各自适配场景+MySQL索引终极选型原因
数据结构·b树·mysql
炸膛坦客4 小时前
嵌入式 - 数据结构与算法:(1-1)数据结构 - 顺序表(Sequential List)
数据结构·算法·嵌入式
水龙吟啸4 小时前
数据结构与算法随机复习–Day1
数据结构·c++·算法
无限进步_6 小时前
C++ 多态机制完全解析:从虚函数重写到动态绑定原理
java·c语言·jvm·数据结构·c++·windows·后端
无限进步_9 小时前
二叉搜索树完全解析:从概念到实现与应用场景
c语言·开发语言·数据结构·c++·算法·github·visual studio
爱写代码的倒霉蛋10 小时前
2022年天梯赛L1-8真题解析(哈希+排序)
数据结构·算法
代码中介商10 小时前
顺序表完全指南:从原理到实现
数据结构·顺序表
澈20710 小时前
C++ list容器完全指南
数据结构·c++·链表
承渊政道12 小时前
【动态规划算法】(完全背包问题从状态定义到空间优化)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法