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

day14 leetcode-hot100-25(链表4)

141. 环形链表 - 力扣(LeetCode)

1.哈希集合

思路

将节点一个一个加入HashSet,并用contains判断是否存在之前有存储过的节点,如果有便是环,如果没有便不是环。

具体代码
/*** Definition for singly-linked list.* class ListNode {*     int val;*     ListNode next;*     ListNode(int x) {*         val = x;*         next = null;*     }* }*/
public class Solution {public boolean hasCycle(ListNode head) {HashSet<ListNode> set = new HashSet<>();ListNode p = head;while(p!=null){if(set.contains(p)){return true;}set.add(p);p=p.next;}return false;}
}

 2.快慢指针

优化空间复杂度为O(1)

思路

一个慢指针每次走1格,一个快指针每次走2格,如果存在环肯定会相遇,如果不存在,最后都为null.

具体代码
/*** Definition for singly-linked list.* class ListNode {*     int val;*     ListNode next;*     ListNode(int x) {*         val = x;*         next = null;*     }* }*/
public class Solution {public boolean hasCycle(ListNode head) {if(head == null){return false;}ListNode slow = head;ListNode fast = head.next;while(slow != null && fast != null){if(slow==fast){return true;}slow=slow.next;if(fast.next!=null){fast = fast.next.next;}else{return false;}}return false;}
}

相关文章:

  • 动态规划之网格图模型(一)
  • 单元测试报错
  • 【ClickHouse】RollingBitmap
  • [3D GISMesh]三角网格模型中的孔洞修补算法
  • Ubuntu 18.04 上源码安装 protobuf 3.7.0
  • java/mysql/ES下的日期类型分析
  • 1、python代码实现与大模型的问答交互
  • 关于位图Bitmaps的介绍
  • js 动画库、2048核心逻辑、面试题add[1][2][3]+4
  • 湖北理元理律师事务所:债务优化中的生活保障实践
  • 图解gpt之Transformer架构与设计原理
  • 第十三篇:MySQL 运维自动化与可观测性建设实践指南
  • DeepSeek-R1-0528
  • 基于云模型与TOPSIS评价算法的综合应用研究
  • 简单说一说Modern ABAP这个概念
  • 专业级图片分割解决方案
  • 【清晰教程】利用Git工具将本地项目push上传至GitHub仓库中
  • 探索C++模板STL
  • 二重积分的线性性
  • Keil MDK5.37或更高版本不再预装ARM Compiler Version5导致编译错误的解决方法
  • 香港最新消息疫情/中国十大seo
  • 做网站建设哪家便宜/成都网络运营推广
  • 绍兴优秀做网站的/搜索网站关键词
  • 做网站维护是什么岗位/全面网络推广营销策划
  • 公司做网站推广/重庆seo顾问
  • 成都专业网站建设费用/百度关键词排名工具