当前位置: 首页 > news >正文

876. 链表的中间结点

876. 链表的中间结点

    • 算法 = 快慢指针 & 题目特征 = 需要对链表中的节点进行遍历,并且需要根据节点之间的相对位置或者距离进行操作

 


题目链接:https://leetcode.cn/problems/middle-of-the-linked-list/

算法 = 快慢指针 & 题目特征 = 需要对链表中的节点进行遍历,并且需要根据节点之间的相对位置或者距离进行操作

思路:用两个指针 slow 与 fast 一起遍历链表。slow 一次走一步,fast 一次走两步。那么当 fast 到达链表的末尾时,slow 必然位于中间。

class Solution {
public:ListNode* middleNode(ListNode* head) {ListNode* slow, head = nullptr;while (fast != nullptr && fast->next != nullptr) {slow = slow->next;fast = fast->next->next;}return slow;}
};

细节处理:如果有两个中间结点,则返回第二个中间结点。

对于一个偶数长度的链表,假设链表中有 6 个节点,节点分别为 1 -> 2 -> 3 -> 4 -> 5 -> 6。

当 slow 和 fast 初始都指向链表的头节点时,slow 每次移动一步,fast 每次移动两步。

  1. 第一步:slow 移动到节点 2,fast 移动到节点 3。
  2. 第二步:slow 移动到节点 3,fast 移动到节点 5。
  3. 第三步:slow 移动到节点 4,fast 移动到节点 6。

此时,fast 到达了链表的末尾,slow 位于链表的中间位置,即节点 4。

根据这个例子,我们可以看到,当链表长度为偶数时,slow 确实返回的是中间的第二个节点,即节点 4。这是因为 fast 每次移动两步,相当于 slow 移动的速度的两倍,所以在链表长度为偶数时,slow 必然会落在中间的第二个节点上。

如果希望返回中间的第一个节点,可以在初始化时让 fast 指向链表的第一个节点,然后进行相同的遍历操作。这样,当 fast 到达链表的末尾时,slow 就会指向中间的第一个节点。
 


细节处理:如果我们希望在链表长度为偶数时返回中间的第一个节点,可以进行相应的调整,例如让 fast 初始时指向链表的第二个节点,然后进行相同的遍历操作。这样,当 fast 到达链表末尾时,slow 就会指向中间的第一个节点。

对于一个偶数长度的链表,假设链表中有 6 个节点,节点分别为 1 -> 2 -> 3 -> 4 -> 5 -> 6。

当 slow 初始指向链表的头节点,fast 初始指向链表的第二个节点时,slow 每次移动一步,fast 每次移动两步。

  1. 第一步:slow 移动到节点 1,fast 移动到节点 3。
  2. 第二步:slow 移动到节点 2,fast 移动到节点 5。
  3. 第三步:slow 移动到节点 3,fast 移动到节点 6。

此时,fast 到达了链表的末尾,slow 位于链表的中间位置,即节点 3。

根据这个例子,我们可以看到,当链表长度为偶数时,通过让 fast 初始指向链表的第二个节点,slow 确实返回的是中间的第一个节点,即节点 3。

所以,通过调整 fast 初始位置,我们可以控制在链表长度为偶数时返回中间的第一个节点还是第二个节点。

http://www.lryc.cn/news/216120.html

相关文章:

  • 【机器学习】二、决策树
  • 低代码PAAS加速推进企业数字化转型
  • 时间复杂度为 O(nlogn) 的排序算法
  • 掌控你的Mac性能:System Dashboard Pro,一款专业的系统监视器
  • C++ Qt如何往Windows AppData目录写数据
  • xargs命令
  • 【原创】java+swing+mysql无偿献血管理系统设计与实现
  • C语言 Number 1 基本数据类型
  • mac录屏快捷键指南,轻松录制屏幕内容!
  • 精准测试是个错误
  • 算法通关村第四关|黄金挑战|表达式问题
  • Mac安装DBeaver
  • C++ 类 根据成员变量的指针获取类对象的指针
  • 图论08-图的建模-状态的表达与理解 - 倒水问题为例
  • sqlserver字符串拼接
  • MySQL-----事务
  • hive的安装配置笔记
  • lamba stream处理集合
  • 操作系统 day04(系统调用)
  • 【深度学习】pytorch——线性回归
  • golang工程——中间件redis,单节点集群部署
  • Lua基础
  • 微信小程序之开发工具介绍
  • 【AUTOSAR】【以太网】DoIp
  • 游戏中UI的性能优化手段
  • Idea快速生成测试类
  • Java文件操作详解
  • 二叉树系列主题Code
  • Leetcode 673. 最长递增子序列的个数 C++
  • html用css grid实现自适应四宫格放视频