【每日一题】LeetCode——链表的中间结点
作者:mmseoamin日期:2024-04-29

【每日一题】LeetCode——链表的中间结点,在这里插入图片描述,第1张

📚博客主页:爱敲代码的小杨.

✨专栏:《Java SE语法》 | 《数据结构与算法》 | 《C生万物》

❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️

🙏小杨水平有限,欢迎各位大佬指点,相互学习进步!

【每日一题】LeetCode——链表的中间结点,第2张

文章目录

  • 1.题目描述
    • 示例1
    • 示例2
    • 提示
    • 2. 思路
    • 3.代码

      1.题目描述

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

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

      示例1

      【每日一题】LeetCode——链表的中间结点,img,第3张

      输入:head = [1,2,3,4,5]

      输出:[3,4,5]

      解释:链表只有一个中间节点,值为3

      示例2

      【每日一题】LeetCode——链表的中间结点,img,第4张

      输入:head = [1,2,3,4,5,6]

      输出:[4,5,6]

      解释:链表只有两个中间节点,值分别为3和4,返回第二个节点。

      提示

      • 链表的节点的范围是[1,100]
      • 1<= Node.val <= 100

        题目链接

        2. 思路

        1. 判断头结点的next是否为空,如果是直接返回头结点
        2. 定义两个指针slow和fast,都指向头结点。
        3. 循环遍历链表,每次fast指向fast的next的next(每次移动两步);slow指向slow的next(每次移动1步)
        4. 循环条件:fast == null循环结束(链表元素个数为偶数时),fast.next == null循环结束(链表元素个数为奇数时)。

        【每日一题】LeetCode——链表的中间结点,image-20231218103009554,第5张

        3.代码

        /**
         * Definition for singly-linked list.
         * public class ListNode {
         *     int val;
         *     ListNode next;
         *     ListNode() {}
         *     ListNode(int val) { this.val = val; }
         *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
         * }
         */
        class Solution {
            public ListNode middleNode(ListNode head) {
                if (head.next == null) {
                    return head;
                }
                ListNode slow = head;
                ListNode fast = head;
                while (fast != null && fast.next != null) {
                    fast = fast.next.next;
                    slow = slow.next;
                }
                return slow;
            }
        }
        

        运行结果:

        【每日一题】LeetCode——链表的中间结点,image-20231218103101436,第6张

        【每日一题】LeetCode——链表的中间结点,第7张