【数据结构与算法】(LeetCode)141.环形链表 142.环形链表Ⅱ

【数据结构与算法】(LeetCode)141.环形链表 142.环形链表Ⅱ

文章目录

引言

环形链表问题是数据结构与算法中的经典问题,在面试中出现频率极高。这类问题不仅考察对链表结构的理解,更考验解决问题的思维能力和数学分析能力。本文将详细分析环形链表的判断方法以及环入口节点的定位算法,帮助读者深入理解这一重要问题。

环形链表判断

问题描述

给定一个链表的头节点 head,判断链表中是否存在环。

在这里插入图片描述

解决方案:快慢指针法

快慢指针法是解决环形链表问题的经典方法,其核心思想是使用两个指针以不同速度遍历链表。

bool hasCycle(structListNode*head){structListNode* slow=head,*fast=head;while(fast&&fast->next){ slow=slow->next; fast=fast->next->next;//一定要先让快慢指针走,再判断 因为一开始快慢指针都是headif(slow==fast)return true;}return false;}

原理分析

为什么快慢指针一定能相遇?

假设慢指针进入环时,快指针与慢指针之间的距离为N。由于快指针每次比慢指针多走一步,它们之间的距离会逐次减少:N, N-1, N-2, …, 2, 1, 0。因此最终一定会相遇。

步长选择的数学分析

为什么选择一步和两步?

当快指针每次走三步、四步或更多时,情况会变得更加复杂。以三步为例:

  • 每次移动后,快慢指针之间的距离减少2
  • 当N为偶数时,可以追上
  • 当N为奇数时,会错过,距离变为C-1(C为环长)
在这里插入图片描述

假设slow进环时,fast跟slow的距离是N

fast追击slow时 距离变化为N N-1 N-2 ……2 1 0

所以能追上

在这里插入图片描述

当fast等于3时,每次fast与slow距离就减2

1.当N为偶数时,可以追上

2.当N为奇数时,会错过,这时他们的距离会变为C-1 (假设C为环的长度)

a.如果C-1为偶数(C为奇数),下一轮就追上了

b.如果C-1为奇数(C为偶数),就永远追不上

所以这么一看,追不上的条件是:N为奇数并且C为偶数

在这里插入图片描述

但是这种情况存在吗?

进一步分析表明,当快指针走三步时,追不上的条件是:N为奇数且C为偶数。但通过数学推导可以证明这种情况实际上不可能发生:

假设slow走的距离是L

fast走的距离就是L+x*C+N (x为fast走的圈数)

fast走的距离是slow的3倍

3L=L+x*C+N

化简可得

2L=x*C+N

当C为偶数N为奇数时,x*C为偶数

等号左边是偶数,右边是偶数加奇数(也就是奇数),显然不成立

所以不存在N为奇数,C为偶数的情况

所以fast一定能追上slow

环形链表Ⅱ

题目如下

在这里插入图片描述

方法一

找到fast与slow相遇的位置meet,head与meet同时走,他们相遇位置就是环的入口

证明如下:

在这里插入图片描述

相遇时:

slow走的路程为:L+N

fast走的路程为: L+x*C+N

fast走的是slow的2倍

2(L+N)=L+x*C+N

化简可得

L=(x-1)*C+C-N

所以L的长度就是相遇点转了x-1圈 再走了C-N距离的点

这意味着:从头节点到环入口的距离L,等于从相遇点走(x-1)圈再加(C-N)步。因此,两个指针分别从头节点和相遇点出发,一定会在环入口相遇。

代码如下

structListNode*detectCycle(structListNode*head){structListNode* slow=head,*fast=head;while(fast&&fast->next){ slow=slow->next; fast=fast->next->next;if(slow==fast){structListNode* meet=slow;while(meet!=head){ head=head->next; meet=meet->next;}return meet;}}returnNULL;}

方法二:转换为相交链表问题

算法思路
  1. 找到快慢指针的相遇点
  2. 将环从相遇点处断开
  3. 问题转换为求两个链表的交点问题
在这里插入图片描述

将环形链表断开

newhead=meet->next

meet->next=NULL

这样就转换成了链表相交的问题

structListNode*getIntersectionNode(structListNode*headA,structListNode*headB){structListNode* curA=headA,*curB=headB;int lenA=1,lenB=1;while(curA->next){ curA=curA->next; lenA++;}while(curB->next){ curB=curB->next; lenB++;}int gap=abs(lenA-lenB);//假设法 先假设A长structListNode* longList=headA;structListNode* shortList=headB;if(lenA<lenB){ longList=headB; shortList=headA;}while(gap--){ longList=longList->next;}while(longList){if(longList==shortList)return longList; longList=longList->next; shortList=shortList->next;}returnNULL;}structListNode*detectCycle(structListNode*head){structListNode* slow=head,*fast=head;while(fast&&fast->next){ slow=slow->next; fast=fast->next->next;if(slow==fast){structListNode* meet=slow;structListNode* newhead=meet->next; meet->next=NULL;returngetIntersectionNode(head,newhead);}}returnNULL;}

实际应用与扩展

应用场景

  1. 内存管理:检测内存泄漏或循环引用
  2. 状态机检测:验证有限状态机是否会进入循环状态
  3. 递归检测:判断递归函数是否会无限递归
    meet->next=NULL;
    return getIntersectionNode(head,newhead);
    }}

return NULL;

}

 ## 实际应用与扩展 ### 应用场景 1. **内存管理**:检测内存泄漏或循环引用 2. **状态机检测**:验证有限状态机是否会进入循环状态 3. **递归检测**:判断递归函数是否会无限递归 4. **哈希冲突解决**:在开放定址法中检测哈希表是否已满 

Read more

从零开始“养龙虾”:OpenClaw 本地极简部署与 QQ 机器人接入全保姆级教程

从零开始“养龙虾”:OpenClaw 本地极简部署与 QQ 机器人接入全保姆级教程

文章目录 * 引言 * 什么是 OpenClaw? * 为什么选择 OpenClaw? * 一、基础环境准备 * 1. 安装 Node.js (v22及以上) * 2.安装 Git * 3. 解决 npm 被拦截(没报错跳过) * 二、一键部署与唤醒“龙虾” * 1.全自动拉取与组装 * 2.醒龙虾与配置“大脑” * 三、接入官方 QQ 机器人(可选) * 1. 领取官方机器人的“身份证” * 2. 本地安装专属通信插件 * 3. 结果展示 * 总结 引言 什么是 OpenClaw? 最近开源界有一只“红皮小龙虾”非常火,它就是 OpenClaw。

By Ne0inhk
Flutter 三方库 wallet_connect 的鸿蒙化适配指南 - 实现 Web3 钱包协议连接、支持 DApp 授权登录与跨链交易签名实战

Flutter 三方库 wallet_connect 的鸿蒙化适配指南 - 实现 Web3 钱包协议连接、支持 DApp 授权登录与跨链交易签名实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 wallet_connect 的鸿蒙化适配指南 - 实现 Web3 钱包协议连接、支持 DApp 授权登录与跨链交易签名实战 前言 在进行 Flutter for OpenHarmony 的去中心化应用(DApp)或加密货币钱包开发时,支持标准的 WalletConnect 协议是链接用户钱包的关键。wallet_connect 是该协议的 Dart 实现,它能让你的鸿蒙 App 安全地与 MetaMask、Trust Wallet 等钱包建立双向加密连接。本文将探讨如何在鸿蒙系统下构建安全、稳定的 Web3 授权流程。 一、原理解析 / 概念介绍 1.1 基础原理

By Ne0inhk

Qwen3-VL-2B部署案例:博物馆导览机器人系统

Qwen3-VL-2B部署案例:博物馆导览机器人系统 1. 引言:视觉语言模型在智能导览中的应用价值 随着人工智能技术的发展,视觉语言模型(Vision-Language Model, VLM)正逐步从实验室走向实际应用场景。在公共服务领域,尤其是博物馆、美术馆等文化场所,智能化导览系统的需求日益增长。传统的语音讲解或静态图文介绍已难以满足用户对交互性、个性化和沉浸式体验的期待。 Qwen3-VL-2B-Instruct 作为阿里云开源的最新一代视觉语言模型,具备强大的图文理解、空间感知与多模态推理能力,为构建高可用的导览机器人系统提供了理想的技术底座。该模型支持图像识别、OCR解析、语义问答、上下文记忆等多种功能,并内置针对指令任务优化的 Instruct 版本,能够快速适配定制化场景。 本文将围绕 Qwen3-VL-2B-Instruct 模型,结合 Qwen3-VL-WEBUI 部署方案,详细介绍其在博物馆导览机器人系统中的落地实践,涵盖环境搭建、功能实现、关键代码及性能优化建议。 2. 技术选型与系统架构设计 2.1 为什么选择 Qwen3-VL-2B-Inst

By Ne0inhk
【PX4+ROS完全指南】从零实现无人机Offboard控制:模式解析与实战

【PX4+ROS完全指南】从零实现无人机Offboard控制:模式解析与实战

引言 无人机自主飞行是机器人领域的热门方向,而PX4作为功能强大的开源飞控,配合ROS(机器人操作系统)的灵活性与生态,成为实现高级自主飞行的黄金组合。然而,许多初学者对PX4的飞行模式理解不清,更不知道如何通过ROS编写可靠的Offboard控制程序。 本文将带你彻底搞懂PX4 6大核心飞行模式,实现无人机的自动起飞、悬停、轨迹跟踪(圆形/方形/螺旋)与降落。 亮点一览: * ✅ 深度解析PX4飞行模式(稳定/定高/位置/自动/Offboard) * ✅ 明确ROS可控制的模式与指令接口 * ✅ 完整的ROS功能包(C++实现,状态机设计) * ✅ 支持位置控制与速度控制双模式 * ✅ 内置圆形、方形、螺旋轨迹生成器 * ✅ 详细的安全机制与失效保护配置 无论你是准备参加比赛、做科研,还是想入门无人机开发,这篇文章都将是你宝贵的参考资料。 第一部分:PX4飞行模式深度剖析 PX4的飞行模式可以看作一个控制权逐级递增的层级结构。理解这些模式是编写控制程序的前提。 1. 稳定模式(STABILIZED / MANUAL / ACRO) * 核心特点:

By Ne0inhk