java求链表中倒数第k个结点

下面我用两种方法求解:

第一种方法:通常我们做这种题就是求出链表的长度=length,然后呢length-k的值就是我们要从链表头部走几步就可以了,代码解释:

java 复制代码
public class Solution {
    public class ListNode {
        int val;
        ListNode next = null;

        ListNode(int val) {
            this.val = val;
        }
    }
    public ListNode FindKthToTail(ListNode head,int k) {
        int length=0;
        ListNode cur=head;//为了不改变head的指向,定义临时变化指针
        while (cur!=null){
            cur=cur.next;
            length++;
        }
        if(k<0 || k>length)return null;//k值越界
        cur=head;
        for (int i = 0; i <length-k ; i++)
            cur=cur.next;
        return cur;

}
}

第二种方法,我们先定义两个指向head的指针,分别是fast和slow,让fast先走(k-1)步后fast和slow一起每次都走一步,当fast.next的值是null结束,这样fast和slow之间永远相差k个元素,我们值遍历一次链表就可以找到倒数第k个值,画图解释:

fast先走k-1步:

fast和slow一起走,每次一步:

代码实现:

java 复制代码
import java.util.*;
/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class Solution {
    public ListNode FindKthToTail(ListNode head,int k) {
         ListNode fast=head,slow=head;
         if(k<=0)return null;
         if (head==null)return null;
        for (int i = 0; i <k-1 ; i++){
            if (fast.next!=null)fast=fast.next;
            else {
                return null;//fast.next==null,但是k还没有走完,证明k值不合法太大了
            }
        }
        //k值合法
        while (fast.next!=null){
            fast=fast.next;
            slow=slow.next;
        }
        return slow;
    
    }
}
相关推荐
疯狂的挖掘机1 小时前
记一次基于QT的图片操作处理优化思路(包括在图上放大缩小,截图,画线,取值等)
开发语言·数据库·qt
cnxy1882 小时前
围棋对弈Python程序开发完整指南:步骤4 - 提子逻辑和劫争规则实现
开发语言·python·机器学习
意趣新2 小时前
C 语言源文件从编写完成到最终生成可执行文件的完整、详细过程
c语言·开发语言
.鸣2 小时前
set和map
java·学习
ha_lydms3 小时前
5、Spark函数_s/t
java·大数据·python·spark·数据处理·maxcompute·spark 函数
李艺为3 小时前
根据apk包名动态修改Android品牌与型号
android·开发语言
黄河滴滴3 小时前
java系统变卡变慢的原因是什么?从oom的角度分析
java·开发语言
侠客行03173 小时前
Mybatis二级缓存实现详解
java·mybatis·源码阅读
老华带你飞3 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
superman超哥4 小时前
Rust Workspace 多项目管理:单体仓库的优雅组织
开发语言·rust·多项目管理·rust workspace·单体仓库