LeetCodeAnimation/notes/LeetCode第141号问题:环形链表.md
2019-06-27 14:57:57 +08:00

81 lines
2.2 KiB
Java
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# 使用快慢指针求解环形链表so easy
> 本文首发于公众号五分钟学算法[图解 LeetCode ](<https://github.com/MisterBooo/LeetCodeAnimation>)系列文章之一。
>
> 个人网站[https://www.cxyxiaowu.com](https://www.cxyxiaowu.com)
今天分享的题目来源于 LeetCode 上第 141 号问题环形链表题目难度为 Easy目前通过率为 40.4%
使用快慢指针的方式去求解 **so easy**
### 题目描述
给定一个链表判断链表中是否有环
为了表示给定链表中的环我们使用整数 `pos` 来表示链表尾连接到链表中的位置索引从 0 开始 如果 `pos` `-1`则在该链表中没有环
**示例 1**
```
输入head = [3,2,0,-4], pos = 1
输出true
解释链表中有一个环其尾部连接到第二个节点
```
![](https://assets.leetcode.com/uploads/2018/12/07/circularlinkedlist.png)
**示例 2**
```
输入head = [1,2], pos = 0
输出true
解释链表中有一个环其尾部连接到第一个节点
```
![](https://assets.leetcode.com/uploads/2018/12/07/circularlinkedlist_test2.png)
**示例 3**
```
输入head = [1], pos = -1
输出false
解释链表中没有环
```
![](https://assets.leetcode.com/uploads/2018/12/07/circularlinkedlist_test3.png)
**进阶**
你能用 O(1)常量内存解决此问题吗
### 题目解析
这道题是快慢指针的**经典应用**
设置两个指针一个每次走一步的**慢指针**和一个每次走两步的**快指针**
* 如果不含有环跑得快的那个指针最终会遇到 null说明链表不含环
* 如果含有环快指针会超慢指针一圈和慢指针相遇说明链表含有环
### 动画描述
![](https://raw.githubusercontent.com/MisterBooo/myBlogPic/master/20190627145511.gif)
### 代码实现
```java
//author:程序员小吴
public class Solution {
public boolean hasCycle(ListNode head) {
ListNode slow = head, fast = head;
while (fast != null && fast.next != null) {
slow = slow.next;
fast = fast.next.next;
if (slow == fast) return true;
}
return false;
}
}
```