当前位置:网站首页>力扣142-环形链表——链表&快慢指针法&哈希表法
力扣142-环形链表——链表&快慢指针法&哈希表法
2022-08-08 07:35:00 【张怼怼√】
题目描述
给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。
如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。注意:pos 不作为参数进行传递,仅仅是为了标识链表的实际情况。
不允许修改 链表。
求解思路
- 本题的求解是参考代码随想录卡哥的解法——快慢指针法;
- 定义一个快指针first:每次前进两步;
- 定义一个慢指针last:每次前进一步;
- 两个指针必定会在环内某个节点相遇;
- 此时分别定义两个指针index1和index2,分别从相遇点和链表头起点head开始运行,每次前进步数为1;
- 当 index1 和 index2 相遇时,此时的节点就是环开始的节点,就是题目所求。
- 题目求解如下:

- 这道题除了用这种比较巧妙的方法求解外还可以采用哈希表存取的方法来求解。
输入输出示例

代码
快慢指针法
/**
* Definition for singly-linked list.
* class ListNode {
* int val;
* ListNode next;
* ListNode(int x) {
* val = x;
* next = null;
* }
* }
*/
public class Solution {
public ListNode detectCycle(ListNode head) {
ListNode fast = head, slow = head;
while(fast != null && fast.next != null){
fast = fast.next.next;
slow = slow.next;
if(fast == slow){
ListNode index1 = fast;
ListNode index2 = head;
while(index1 != index2){
index1 = index1.next;
index2 = index2.next;
}
if(index1 == index2) return index1;
}
}
return null;
}
}哈希表法
/**
* Definition for singly-linked list.
* class ListNode {
* int val;
* ListNode next;
* ListNode(int x) {
* val = x;
* next = null;
* }
* }
*/
public class Solution {
public ListNode detectCycle(ListNode head) {
ListNode pos = head;
Set<ListNode> set = new HashSet<>();
while(pos != null){
if(set.contains(pos)){
return pos;
}else{
set.add(pos);
}
pos = pos.next;
}
return null;
}
}边栏推荐
猜你喜欢
随机推荐
在 TensorFlow 中构建 3D-CNN
了不起的certbot申请免费SSL证书
Want to use SQL to achieve two days after the data contrast, the new data sheet and a list of tags
IIC通讯协议与EEPROM简介
字符串常见方法总结:方法的作用、参数、返回值(构造方法可省略)1. 构造方法2. 静态方法3. 其它方法
易语言设置多个热键
Monorepo[单一代码库] 与MicroService[微服务] 架构
C语言内存分配相关知识
快速排序
剪切字符串函数
用于一型糖尿病血糖调节的无模型iPID控制器
Deep-4mCGP:一种使用基于相关性的特征选择技术预测pickeringii地杆菌中4mC位点的深度学习方法
动手学概率论(2)
云服务器搭建MQTT消息代理EMQX
Spiral Matrix
文件包含漏洞-知识点
超强的企业建站系统介绍:功能模块
日常用到的开源软件列表
Task 06 其它优秀的小工具
throw 和 throws 有什么区别










