【百日算法计划】:每日一题,见证成长(016)

题目

环形链表

给你一个链表的头节点 head ,判断链表中是否有环

思路1

用哈希表的思想,遍历链表,判断节点在哈希表中是否存在。

java 复制代码
 public boolean hasCycle2(ListNode head) {
     HashSet<ListNode> hashSet = new HashSet<>();
     ListNode p = head;
     while (p != null){
         if (hashSet.contains(p)) return true;
         hashSet.add(p);
         p = p.next;
     }
     return false;
 }

思路2

快慢指针,慢指针走一步,快指针走两步,等快指针与慢指针重合时,即有环。

java 复制代码
public boolean hasCycle(ListNode head) {
  if (head == null) return false;
  ListNode p = head; //慢指针
  ListNode q = head.next; //快指针 为啥初始值在第二个节点,不是第一个节点,如果也在第一个节点 下面的while循环 直接就return true了
  while (q != null && q.next != null && p != q){
     p = p.next;
     q = q.next.next; //快指针每次走两步,如果只走一步,那么快指针永远只领先慢指针一步,永远不会相遇
  }
  if (p == q) return true;
  else return false;
}
相关推荐
做怪小疯子几秒前
LeetCode 热题 100——二叉树——二叉树的中序遍历
算法·leetcode·职场和发展
一只乔哇噻8 分钟前
java后端工程师+AI大模型进修ing(研一版‖day57)
java·开发语言·人工智能·算法·语言模型
晨曦夜月19 分钟前
笔试强训day4
算法
自然语28 分钟前
人工智能之数字生命-学习的过程
数据结构·人工智能·深度学习·学习·算法
Yuezero_39 分钟前
Research Intern面试(一)——手敲LLM快速复习
pytorch·深度学习·算法
wyiyiyi1 小时前
【数据结构+算法】非递归遍历二叉树的理解
大数据·数据结构·笔记·算法·leetcode·数据分析
2401_893326621 小时前
力扣1971.寻找图中是否存在路径
算法·leetcode·职场和发展
zs宝来了1 小时前
HOT100-技巧类型题
数据结构·算法
Ayanami_Reii1 小时前
进阶数据结构-FenwickTree
数据结构·算法·树状数组·fenwick tree
爪哇部落算法小助手1 小时前
每日两题day59
数据结构·c++·算法