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;
    }
相关推荐
Miraitowa_cheems7 小时前
LeetCode算法日记 - Day 73: 最小路径和、地下城游戏
数据结构·算法·leetcode·职场和发展·深度优先·动态规划·推荐算法
野蛮人6号7 小时前
力扣热题100道之560和位K的子数组
数据结构·算法·leetcode
Swift社区8 小时前
LeetCode 400 - 第 N 位数字
算法·leetcode·职场和发展
fengfuyao9859 小时前
BCH码编译码仿真与误码率性能分析
算法
Predestination王瀞潞9 小时前
Java EE开发技术(Servlet整合JDBC银行管理系统-上)
java·servlet·java-ee·jdbc
寻星探路9 小时前
Java EE初阶启程记13---JUC(java.util.concurrent) 的常见类
java·开发语言·java-ee
小白不想白a9 小时前
每日手撕算法--哈希映射/链表存储数求和
数据结构·算法
怪兽201410 小时前
什么是 Redis?
java·数据库·redis·缓存·面试
剪一朵云爱着10 小时前
力扣2080. 区间内查询数字的频率
算法·leetcode
Gu_yyqx10 小时前
Java 队列
java