【每日一题】LeetCode——链表的中间结点

在这里插入图片描述

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

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

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

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

1.题目描述

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

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

示例1

img

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

输出:[3,4,5]

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

示例2

img

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

输出:[4,5,6]

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

提示

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

题目链接

2. 思路

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

image-20231218103009554

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;
    }
}

运行结果:

image-20231218103101436

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-02-08 23:42:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-08 23:42:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-08 23:42:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-08 23:42:02       18 阅读

热门阅读

  1. 如何清理Docker占用的磁盘空间?

    2024-02-08 23:42:02       27 阅读
  2. 第63讲个人中心用户信息动态显示实现

    2024-02-08 23:42:02       32 阅读
  3. 设计模式(行为型模式)观察者模式

    2024-02-08 23:42:02       30 阅读
  4. 打卡今天学习的命令 (linux

    2024-02-08 23:42:02       29 阅读
  5. 【运维】htop 安装及使用

    2024-02-08 23:42:02       34 阅读
  6. 深入学习Prometheus! 一款开源的监控和警报工具!

    2024-02-08 23:42:02       28 阅读
  7. Hyper-V 调整 设置 Ubuntu 虚拟机的分辨率

    2024-02-08 23:42:02       29 阅读
  8. <网络安全>《20 工业防火墙》

    2024-02-08 23:42:02       28 阅读
  9. C#的Char 结构的像IsLetterOrDigit(Char)等常见的方法

    2024-02-08 23:42:02       25 阅读