【百日算法计划】:每日一题,见证成长(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;
}
相关推荐
进击的荆棘2 分钟前
优选算法——分治
数据结构·算法·leetcode·分治
Yupureki4 分钟前
《实战项目-个人在线OJ平台》1.项目简介和演示
c语言·数据结构·c++·sql·算法·性能优化·html5
m0_5793936611 分钟前
C++代码混淆与保护
开发语言·c++·算法
qq_1481153712 分钟前
C++中的享元模式实战
开发语言·c++·算法
Yzzz-F18 分钟前
Problem - D2 - Codeforces
算法
烟花巷子18 分钟前
C++中的解释器模式
开发语言·c++·算法
暮冬-  Gentle°23 分钟前
C++中的策略模式高级应用
开发语言·c++·算法
2401_8796938726 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
地平线开发者26 分钟前
【地平线J6工具链入门教程】J5到J6算法部署迁移指南
人工智能·算法·自动驾驶·汽车
木井巳29 分钟前
【递归算法】找出所有子集的异或总和再求和
java·算法·leetcode·决策树·深度优先