当前位置:网站首页>力扣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;
}
}
边栏推荐
猜你喜欢
论文翻译:《6mAPred-MSFF:基于多尺度特征融合机制预测跨物种DNA N6-甲基腺嘌呤位点的深度学习模型》
看顶级测工怎么玩转Apifox接口测试工具
基于FTP协议的文件上传与下载
论文解读:《4mcPred-CNN—使用卷积神经网络预测小鼠基因组中的DNA N4-甲基胞嘧啶》
论文解读:《Mouse4mC-BGRU:用于预测小鼠基因组中DNA N4-甲基胞嘧啶位点的深度学习》
XXL-JOB入门教学
BLE安全之SM剖析(3)
生产者消费者模型
炽热如初 向新而生|ISC2022 HackingClub白帽峰会圆满举办
CesiumJS 更新日志 1.96 与 1.97 - 新构建工具 esbuild 体验及 Model API 更替完成
随机推荐
生产者消费者模型
Monorepo[单一代码库] 与MicroService[微服务] 架构
炽热如初 向新而生|ISC2022 HackingClub白帽峰会圆满举办
最强分布式锁工具:Redisson
WinForm(四)一种实现登录的方式
Spiral Matrix
选择适合投稿的英文期刊或会议的方法
字符串常见方法
oracle如何删除表并且释放表空间
djanjo第四次培训
Detection of transcription factors binding to methylatedDNA by deep recurrent neural network
动手学线性代数
论文解读:《4mcPred-CNN—使用卷积神经网络预测小鼠基因组中的DNA N4-甲基胞嘧啶》
不一样的“能ping通不能上网”解决方法
蓝牙5.2新特性 LE Audio - Isochronous channel
论文解读:《Amy pred-FRL是一种通过使用特征表示学习来精确预测淀粉样蛋白的新方法》
throw和throws区别
matlab simulink串级变比值模糊PID烟气脱硫浆液pH值控制
Source Insight 4.0 安装过程及简单使用
文件包含漏洞-知识点