题目

给定一个链表,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。注意:pos 不作为参数进行传递,仅仅是为了标识链表的实际情况。

如果链表中存在环,则返回 true 。 否则,返回 false 。

示例 1:

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

img

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

img

输入:head = [1], pos = -1
输出:false
解释:链表中没有环。

题解思路

经典的快慢指针题,定义两个指针,一个一次走两步为快指针,另一个一次走一步为满指针,假设链表上有环,那么,未来的某一刻(一直重复循环)两个指针一定会相遇,否则,两个指针一定遇不到,快指针一定先到达null

代码实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/**
* Definition for singly-linked list.
* function ListNode(val) {
* this.val = val;
* this.next = null;
* }
*/

/**
* @param {ListNode} head
* @return {boolean}
*/
var hasCycle = function(head) {
// 快慢指针,如果有环,快慢指针最终一定会在一个节点上相遇,如果没有环,两个指针一定不会相遇
if (!head) return false;
let fast = slow = head;
while (fast && fast.next) {
fast = fast.next.next;
slow = slow.next;
if (slow === fast) return true;
}
return false;
};