Day11-环形链表
🔗 LeetCode 141 - Linked List Cycle
📌 题目描述
给定一个链表,判断链表中是否有环。
为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。
示例:
| 1 | 输入:head = [3,2,0,-4], pos = 1 | 
💡 解题思路
使用快慢指针:
- 慢指针一次走一步; 
- 快指针一次走两步; 
- 如果链表有环,快慢指针最终会在某个节点相遇; 
- 如果无环,快指针会先走到 - null。
- 时间复杂度:O(n) 
- 空间复杂度:O(1) 
✅ JavaScript 实现(快慢指针)
| 1 | var hasCycle = function(head) { | 
🧠 思考拓展
- 如果需要找出环的入口节点怎么做?(参见 LeetCode 142)
- 如果想统计环的长度呢?
- 使用哈希表是否也能解决?时间与空间复杂度如何变化?