链表中环的入口结点 【空间复杂度O(1)】

题目:

给一个链表,若其中包含环,则返回环的入口结点,否则返回null。

思路:

思路一:

遍历整个链表,将链表中的每个结点都存在哈希表中,如果遇到重复结点,那这个结点就是环的入口结点。时间复杂度和空间复杂度都是O(n)。

思路二:

快慢指针法,通过一个快指针和一个慢指针遍历整个链表,如果两个指针相遇,则说明链表中有环。

知道有环之后,应该怎么快速找到环的入口呢?如下图所示:

假设黄色路线是慢指针走过的路径,红色路线是快指针走过的路径,由于快指针速度是慢指针的二倍,所以通过简单的化简就能得到环中慢指针未走的长度刚好是环外部分的长度!所以再安排一个指针从起点出发,这个新指针与慢指针相遇的位置刚好就是环的入口。(上图中的直线与环的长度刚好合适,如果某个部分过长,可能会绕几圈再相遇,结论依然是一样的)这种方法的时间复杂度依然是O(n),空间复杂度降为了O(1)。

代码:

public class Solution {

    public ListNode EntryNodeOfLoop(ListNode pHead){

        ListNode f = pHead;

        ListNode s = pHead;

        if (pHead==null||pHead.next == null) return null;

        do{

            f = f.next.next;

            s = s.next;

        }while(f!=null&&f.next!=null&&f!=s);

        if (f==null||f.next == null) return null;

        ListNode ns = pHead;

        while (ns!=s){

            ns = ns.next;

            s = s.next;

        }

        return ns;

    }

}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 判断链表有没有环有环链表一般我们采取快慢指针来判断链表是否有环。思路主要是:定义两个指针。fast和slow;fa...
    丨ouo丨阅读 4,583评论 0 0
  • 什么是数组? 数组简单来说就是将所有的数据排成一排存放在系统分配的一个内存块上,通过使用特定元素的索引作为数组的下...
    启明_b56f阅读 4,538评论 0 0
  • 链表 概念 说到链表,coder们都不会陌生,在日常开发中或多或少都会用到它。它是链式存储的线性表,简称链表。链表...
    扈扈哈嘿阅读 6,210评论 0 5
  • 基本概念 链表的含义: 链表是一种用于存储数据集合的数据结构,具有以下属性 相邻元素之间通过指针相连 最后一个元素...
    古剑诛仙阅读 4,587评论 0 3
  • 大学的时候不好好学习,老师在讲台上讲课,自己在以为老师看不到的座位看小说,现在用到了老师讲的知识,只能自己看书查资...
    和珏猫阅读 5,314评论 1 3