LeetCode 876. 链表的中间结点

题目描述:

给你单链表的头结点 head ,请你找出并返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点。

示例 1:

复制代码
输入:head = [1,2,3,4,5]
输出:[3,4,5]
解释:链表只有一个中间结点,值为 3 。

示例 2:

复制代码
输入:head = [1,2,3,4,5,6]
输出:[4,5,6]
解释:该链表有两个中间结点,值分别为 3 和 4 ,返回第二个结点。

代码:

复制代码
//奇数:p1走一步,p2走两步,p2.next!=null
    //偶数:p1走一步,p2走两步,p2!=null
    public ListNode middleNode(ListNode head){
        ListNode p1=head;
        ListNode p2=head;
        while(p2!=null&&p2.next!=null){//偶数:p2!=null(短路运算符写在前面,奇数:p2.next!=null
            p1=p1.next;
            p2=p2.next.next;
        }
        return p1;
    }
相关推荐
唐青枫15 分钟前
Java Future 与 CompletableFuture 实战指南:从异步结果到任务编排
java
Jerry16 分钟前
LeetCode 59. 螺旋矩阵 II
算法
长孙豪翔23 分钟前
在.net中读写config文件的各种方法
java·数据库·.net
tachibana224 分钟前
hot100 回文链表(234)
java·网络·数据结构·leetcode·链表
可编程芯片开发27 分钟前
基于FOC控制器的BLDC无刷直流电机控制系统matlab编程与仿真
算法
可乐ea30 分钟前
【Java八股|第10篇】Java 中的包装类和自动拆装箱
java·面试题·包装类·java八股
zfoo-framework41 分钟前
mongo最佳实战(from mongo中文社区)
java
aaaameliaaa1 小时前
进制练习题【找出只出现一次的数字、交换两个变量(不创建临时变量)、统计二进制中1的个数、打印整数二进制的奇数位和偶数位、求两个数二进制中不同位的个数】
c语言·数据结构·笔记·算法
深盾科技_Virbox1 小时前
加密狗授权能力选型:从授权模型到全生命周期管理
java·网络·数据库
. . . . .2 小时前
Egg框架深入
java·开发语言