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

C++面试(8)-----求链表中环的入口节点

  • 操作系统:ubuntu22.04
  • IDE:Visual Studio Code
  • 编程语言:C++11

题目描述:

给一个链表,如果有环,请找出该链表的入环节点;如果没有环,则返回 null。

你不能修改链表本身。
示例:

输入链表: 3 -> 2 -> 0 -> -4↖        ↗\______/
环的入口是节点 2

解题思路(经典双指针法)

判断链表是否有环,并找出环的入口节点,是一个非常经典的算法问题。我们可以使用快慢指针 + 数学推导的方法来解决。
步骤详解:

  • 第一步:判断是否有环(快慢指针)

    • 定义两个指针 slow 和 fast,都从头节点出发;
    • slow 每次走一步,fast 每次走两步;
    • 如果链表有环,两个指针一定会相遇;
    • 如果 fast 或 fast->next 为 nullptr,说明无环。
  • 第二步:找到环的入口节点
    假设:

    • 头节点到环入口的距离为 a;
    • 环入口到相遇点的距离为 b;
    • 相遇点绕回环入口的距离为 c。

通过数学推导可以得出:

当第一次相遇时,让 fast 回到头节点,并且每次只走一步;
再次相遇的位置就是环的入口。

实现代码

// 定义链表节点结构体
struct ListNode {int val;ListNode* next;ListNode( int x ) : val( x ), next( nullptr ) {}
};class Solution {
public:// 函数功能:查找链表中环的入口节点ListNode* detectCycle( ListNode* head ){// 如果头节点为空,直接返回 nullif ( head == nullptr )return nullptr;// 定义快慢指针ListNode* slow = head;ListNode* fast = head;// 第一次遍历:判断是否有环while ( fast != nullptr && fast->next != nullptr ){slow = slow->next;        // 慢指针每次走一步fast = fast->next->next;  // 快指针每次走两步// 如果相遇,说明有环if ( slow == fast ){// 第二次遍历:找环的入口fast = head;  // 快指针回到头节点while ( fast != slow ){fast = fast->next;slow = slow->next;}return fast;  // 返回环的入口节点}}// 如果没相遇,说明没有环return nullptr;}
};#include <iostream>int main()
{// 构建测试链表:3 -> 2 -> 0 -> -4 -> 2(形成环)ListNode* node1 = new ListNode( 3 );ListNode* node2 = new ListNode( 2 );ListNode* node3 = new ListNode( 0 );ListNode* node4 = new ListNode( -4 );node1->next = node2;node2->next = node3;node3->next = node4;node4->next = node2;  // 形成环Solution sol;ListNode* entryNode = sol.detectCycle( node1 );if ( entryNode != nullptr ){std::cout << "环的入口节点值为:" << entryNode->val << std::endl;}else{std::cout << "该链表没有环。" << std::endl;}return 0;
}

运行结果

环的入口节点值为:2
http://www.xdnf.cn/news/13780.html

相关文章:

  • C++面试(6)-----调整数组顺序使奇数位于偶数前面
  • CodeForces 1453C. Triangles
  • QOpenGLWidget 中能同时显示 .step 的结构树和渲染图吗
  • 快递鸟电商退换货技术全解析:构建智能化逆向物流管理体系
  • IT运维的365天--028 批处理自行检测并以管理员权限运行
  • vue3 常见引用
  • 伊吖学C笔记(6、数、求和、排列)
  • 模拟电路的知识
  • 如何通过插件系统打造个性化效率工作流
  • go部分语法记录
  • 【Fifty Project - D36】
  • 2025pmx文件怎么打开blender和虚幻
  • 林业资源多元监测技术守护绿水青山
  • 说一下Java里面线程池的拒绝策略
  • 从实验室到实践:无人机固件越权提取技术解析
  • DNS常用的域名记录
  • 品融电商:头部全域电商代运营,助品牌决胜多平台时代
  • supervisorctr命令简介
  • 翻译核心词汇
  • React中修改 state 时必须返回一个新对象 (immutable update)
  • Windows环境变量原理(用户变量与系统变量)(用户环境变量、系统环境变量)
  • 解锁 AI 短视频创作密码,开启你的创意之旅
  • DOcplex用法锦集(持续更新)
  • CKA考试知识点分享(12)---configmap
  • 【Android Studio】新建项目及问题解决
  • python3如何使用QT编写基础的对话框程序
  • 【开发常用命令】:服务器与本地之间的数据传输
  • wsl 安装vllm 0.9.1 + torch 2.7.0 + xformers 0.0.30 + flashinfer
  • RocketMQ 客户端编程模型
  • 第28节 Node.js 文件系统