正文
1 题目描述
给定一个链表,返回链表开始入环的第一个节点。如果链表无环,则返回 null。
为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。
说明:不允许修改给定的链表。
示例 1:
输入:head = [3,2,0,-4], pos = 1 输出:tail connects to node index 1 解释:链表中有一个环,其尾部连接到第二个节点。
示例 2:
输入:head = [1,2], pos = 0 输出:tail connects to node index 0 解释:链表中有一个环,其尾部连接到第一个节点。
示例 3:
输入:head = [1], pos = -1 输出:no cycle 解释:链表中没有环。
2.我的代码
/** * Definition for singly-linked list. * class ListNode { * int val; * ListNode next; * ListNode(int x) { * val = x; * next = null; * } * } */ public class Solution { private Object NULL = new Object(); public ListNode detectCycle(ListNode head) { Map<ListNode, Object> map = new HashMap<>(); while (head != null) { Object o = map.get(head); if (null != o) { return head; }else { map.put(head,NULL); head=head.next; } } return null; } }
3 其他人的解法
/** * 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 slow=head; ListNode fast=head; while(true){ //一直循环,若快慢指针相遇,则退出 //判断是否为非环链表 if(fast==null||fast.next==null){ return null; //返回null } slow=slow.next; fast=fast.next.next; if(slow==fast){ //相遇,跳出循环 break; } } ListNode mNode=head; while(mNode!=slow){ //使得第二次相遇,相遇即为入口 mNode=mNode.next; slow=slow.next; } return mNode; } }