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

【力扣刷题C++】环形链表

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/linked-list-cycle
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


【题目】给你一个链表的头节点 head ,判断链表中是否有环。如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。
如果链表中存在环 ,则返回 true 。 否则,返回 false 。

  • 示例 1:
    输入:head = [3,2,0,-4], pos = 1
    输出:true
    解释:链表中有一个环,其尾部连接到第二个节点。
  • 示例 2:
    输入:head = [1,2], pos = 0
    输出:true
    解释:链表中有一个环,其尾部连接到第一个节点。
  • 示例 3:
    输入:head = [1], pos = -1
    输出:false
    解释:链表中没有环。

提示:
链表中节点的数目范围是 [0, 104]
-105 <= Node.val <= 105
pos 为 -1 或者链表中的一个 有效索引 。

进阶:你能用 O(1)(即,常量)内存解决此问题吗?


首次提交

借用哈希表,只存放键,即每个节点的地址。遍历链表并插入set中,如果插入失败说明存在相同地址的结点,成功找到环。

执行用时:16 ms, 在所有 C++ 提交中击败了23.67%的用户
内存消耗:10.3 MB, 在所有 C++ 提交中击败了15.29%的用户

std::set::insert()返回值为std::pair<std::unordered_set<int>::iterator, bool>
参数1:为插入后的元素迭代器,如果插入失败则返回已存在的该元素迭代器。
参数2:插入成功或失败

class Solution {
public:bool hasCycle(ListNode *head) {std::unordered_set<ListNode*> sets;while (head) {if (!sets.insert(head).second)return true;head = head->next;}return false;}
};

根据提示用快慢指针试试
执行用时:8 ms, 在所有 C++ 提交中击败了92.34%的用户
内存消耗:7.9 MB, 在所有 C++ 提交中击败了47.33%的用户

class Solution {
public:bool hasCycle(ListNode *head) {if (!head || !head->next){return false;}ListNode* fast = head;ListNode* slow = head;while (fast->next && fast->next->next) {fast = fast->next->next;slow = slow->next;if (fast == slow){	// 如果是环,总会追上的return true;}}return false;}
};
http://www.lryc.cn/news/98890.html

相关文章:

  • 如何用Python统计CSDN质量分
  • gin框架内容(三)--中间件
  • 如何在工作中利用Prompt高效使用ChatGPT
  • uniapp-小程序button分享传参,当好友通过分享点开该页面时,进行一些判断……
  • Ceph部署方法介绍
  • GoogleLeNet V2 V3 —— Batch Normalization
  • Mac 系统钥匙串证书不受信任
  • 一个企业级的文件上传组件应该是什么样的
  • 安全渗透重点内容
  • 【触觉智能Purple Pi OH开发板体验】开箱体验:开源主板Purple Pi RK3566 上手指北
  • flink1.16使用消费/生产kafka之DataStream
  • 【多任务编程-线程通信】
  • K8S暴露pod内多个端口
  • Python 列表
  • Rabbitmq的安装与使用(Linux版)
  • Kubernetes对象深入学习之四:对象属性编码实战
  • 深度学习入门教程(2):使用预训练模型来文字生成图片TextToImageGenerationWithNetwork
  • ORA-38760: This database instance failed to turn on flashback database
  • 避免低级错误:深入解析Java的ConcurrentModificationException异常
  • 7.28
  • java线程中的常见方法(详解)
  • 线程池参数配置
  • Spread for Winform 16.2.20231.0 (SP2) Crack
  • Go程序结构
  • JAVA面试总结-Redis篇章(四)——双写一致性
  • 赋能医院数字化转型,医院拍摄VR全景很有必要
  • Vue3项目中没有配置 TypeScript 支持,使用 TypeScript 语法
  • 数据可视化大屏拼接屏开发实录:屏幕分辨率测试工具
  • 每日一题7.28 209
  • Python + Playwright 无头浏览器Chrome找不到元素