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;
    }
相关推荐
一路往蓝-Anbo几秒前
【第20期】延时的艺术:HAL_Delay vs vTaskDelay
c语言·数据结构·stm32·单片机·嵌入式硬件
皮皮林55111 分钟前
Prometheus+Grafana,打造强大的监控与可视化平台
java
JasmineWr19 分钟前
CompletableFuture相关问题
java·开发语言
零雲21 分钟前
java面试:知道java的反射机制吗
java·开发语言·面试
Aaron158830 分钟前
AD9084和Versal RF系列具体应用案例对比分析
嵌入式硬件·算法·fpga开发·硬件架构·硬件工程·信号处理·基带工程
laocooon52385788630 分钟前
插入法排序 python
开发语言·python·算法
java1234_小锋1 小时前
Java进程占用的内存有哪些部分?
java
wuhen_n1 小时前
LeetCode -- 1:两数之和(简单)
javascript·算法·leetcode·职场和发展
sxlishaobin1 小时前
Spring Bean生命周期详解
java·后端·spring
曹牧1 小时前
Java:Assert.isTrue()
java·前端·数据库