Time:2019/4/7
Title: Linked List Cycle
Difficulty: Easy
Author:小鹿
javascript
Given a linked list, determine if it has a cycle in it.java
To represent a cycle in the given linked list, we use an integer pos
which represents the position (0-indexed) in the linked list where tail connects to. If pos
is -1
, then there is no cycle in the linked list.node
Example 1:git
Input: head = [3,2,0,-4], pos = 1
Output: true
Explanation: There is a cycle in the linked list, where tail connects to the second node.
复制代码
Example 2:github
Input: head = [1,2], pos = 0
Output: true
Explanation: There is a cycle in the linked list, where tail connects to the first node.
复制代码
Example 3:算法
Input: head = [1], pos = -1
Output: false
Explanation: There is no cycle in the linked list.
复制代码
Follow up:编程
Can you solve it using O(1) (i.e. constant) memory?bash
两种解题思路:ui
1)哈希表法:遍历链表,没遍历一个节点就要在哈希表中判断是否存在该结点,若是存在,则为环;不然,将该结点插入到哈希表中继续遍历。this
2)用两个快慢指针,快指针走两步,慢指针走一步,若是快指针与慢指针重合了,则检测的当前链表为环;若是当前指针或下一指针为 null ,则链表不为环。
/** * Definition for singly-linked list. * function ListNode(val) { * this.val = val; * this.next = null; * } */
/** * @param {ListNode} head * @return {boolean} */
var hasCycle = function(head) {
let fast = head;
let map = new Map();
while(fast !== null){
if(map.has(fast)){
return true;
}else{
map.set(fast);
fast = fast.next;
}
}
return false;
};
复制代码
var hasCycle = function(head) {
if(head == null || head.next == null){
return false;
}
let fast = head.next;
let slow = head;
while(slow != fast){
if(fast == null || fast.next == null){
return false;
}
slow = slow.next;
fast = fast.next.next;
}
return true;
};
复制代码
这部分代码是我本身写的,和上边的快慢指针思路相同,运行结果相同,可是当运行在 leetcode 时,就会提示超出时间限制,仔细对比代码,咱们能够发现,在逻辑顺序上仍是存在差异的,之因此超出时间限制,是由于代码的运行耗时长。
//超出时间限制
var hasCycle = function(head) {
if(head == null || head.next == null){
return false;
}
let fast = head.next;
let slow = head;
while(fast !== null && fast.next !== null){
if(slow === fast) return true;
slow = head.next;
fast = fast.next.next;
}
return false;
};
复制代码
欢迎一块儿加入到 LeetCode 开源 Github 仓库,能够向 me 提交您其余语言的代码。在仓库上坚持和小伙伴们一块儿打卡,共同完善咱们的开源小仓库! Github:https://github.com/luxiangqiang/JS-LeetCode 欢迎关注我我的公众号:「一个不甘平凡的码农」,记录了本身一路自学编程的故事。