欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java:给定一个带有头结点 head 的非空单链表,返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点

程序员文章站 2022-07-10 20:15:12
...

定义两个引用fast和slow,fast每次走两步,slow每次走一步,当fast走到链表尾部时,slow处于链表中间结点。

class Solution {
    public ListNode middleNode(ListNode head) {
        if (head==null) {
            return null;
        }
        ListNode fast = head;
        ListNode slow = head;
        while (fast != null && fast.next != null) {
            fast = fast.next.next;
            slow = slow.next;
        }
        return slow;
    }
}

 

推荐阅读