【❤️算法笔记❤️】-(每日一刷-876、单链表的中点)

文章目录

题目

给你单链表的头结点 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

Related Topics

链表

双指针

👍 977

👎 0

思路

  • 快慢指针
  • slow指针和fast指针都指向head头节点,每当slow前进一步,fast指针就前进两步,当fast指针到链表末尾的时候,slow指针就到中点了。

解法

//给你单链表的头结点 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 ,返回第二个结点。
// 
//
// 
//
// 提示: 
//
// 
// 链表的结点数范围是 [1, 100] 
// 1 <= Node.val <= 100 
// 
//
// Related Topics 链表 双指针 👍 977 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
/**
 * 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) {
        //快慢指针初始化指向头节点
        ListNode fast=head,slow=head;
        //慢指针走一步,快指针走两步
        while (fast!=null&&fast.next!=null){
            //慢指针走一步,快指针走两步
            slow=slow.next;
            fast=fast.next.next;
        }
        //慢指针指向中点
        return slow;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

最近更新

  1. TCP协议是安全的吗?

    2024-03-11 20:18:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-11 20:18:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-11 20:18:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-11 20:18:03       20 阅读

热门阅读

  1. 一个Flutter BLoC入门的简单 demo

    2024-03-11 20:18:03       21 阅读
  2. 使用k8s前配置环境

    2024-03-11 20:18:03       23 阅读
  3. Node.js基础---使用Express写接口

    2024-03-11 20:18:03       21 阅读
  4. 鸿蒙网络请求

    2024-03-11 20:18:03       23 阅读
  5. 02 数据结构之链表

    2024-03-11 20:18:03       22 阅读
  6. 通过Spring Boot 实现页面配置生成动态接口?

    2024-03-11 20:18:03       19 阅读