一、题目描述
给你一个链表的头节点 head ,判断链表中是否有环。
如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。
如果链表中存在环 ,则返回 true 。 否则,返回 false 。
输入:head = [3,2,0,-4], pos = 1
输出:true
解释:链表中有一个环,其尾部连接到第二个节点。
二、思路
这道题有两种解法:哈希表判断重复、快慢指针算相遇
-
哈希表 核心思想:如果存在环,则哈希表必将重复,我们只需要将链表逐个添加到哈希表,判断是否重复,有就返回true
-
快慢指针 核心思想,如果存在环,则快慢指针终会相遇,我们只需要判断快指针是否与慢指针相遇,有就返回true
三、代码展示
- 哈希表
var hasCycle = function(head) { let set = new Set() while(head) { if(set.has(head)) { return true } set.add(head) head = head.next } return false };
- 快慢指针
var hasCycle = function (head) { let slow = head; let fast = head; //如果没有环,则快指针会抵达终点,否则继续移动双指针 while (fast && fast.next) { slow = slow.next; fast = fast.next.next; //快慢指针相遇,说明含有环 if (slow == fast) { return true; } } return false; };