有环单链表相交判断

如何判断两个有环单链表是否相交?相交的话返回true,不想交的话返回false。如果两个链表长度分别为N和M,请做到时间复杂度O(N+M),额外空间复杂度O(1)。
给定两个链表的头结点head1head2(注意,另外两个参数adjust0adjust1用于调整数据,与本题求解无关)。请返回一个bool值代表它们是否相交。

思路

两个有环链表如果相交,只存在图示三种情况.
所以首先我们都要找到两个链表的入环节点entry1entry2.如果entry1==entry2,则属于情况(1)或者(2),直接返回true即可.
否则从entry1或者entry2开始遍历,绕环一圈,如果中途发现有等于另一个entry的点,则说明属于(3). 否则就是不相交的两个有环链表.

有环链表相交的三种情况

import java.util.*;
/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class ChkIntersection {
    public boolean chkInter(ListNode head1, ListNode head2, int adjust0, int adjust1) {
        ListNode entry1=findCycleEntry(head1);
        ListNode entry2=findCycleEntry(head2);
        if(entry1==entry2){
          return true;
        }
        else{
            ListNode backup=entry1;
            do{
                entry1=entry1.next;
            }while(entry1!=entry2&&entry1!=backup);
            return !(entry1==backup);
        }
    }
  
    
    //找到入环节点
    private ListNode findCycleEntry(ListNode head){
        if(head==null||head.next==null)return null;
        ListNode fast=head,slow=head;
        do{
            slow=slow.next;
            fast=fast.next.next;

        }while(slow!=fast&&fast.next!=null&&fast.next.next!=null);
        if(slow!=fast)return null;
        slow=head;
        while(slow!=fast){
            fast=fast.next;
            slow=slow.next;
        }
        return slow;
    }    
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 题目 如何判断两个有环单链表是否相交?相交的话返回第一个相交的节点,不想交的话返回空。如果两个链表长度分别为N和M...
    郑明明阅读 764评论 0 1
  • //leetcode中还有花样链表题,这里几个例子,冰山一角 求单链表中结点的个数----时间复杂度O(n)这是最...
    暗黑破坏球嘿哈阅读 1,535评论 0 6
  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 3,371评论 0 19
  • 1. 链表 链表是最基本的数据结构,面试官也常常用链表来考察面试者的基本能力,而且链表相关的操作相对而言比较简单,...
    Mr希灵阅读 1,472评论 0 20
  • 煮一壶茶 将滚烫的热 行云流水般注入杯中 透明的玻璃杯底 一撮小小的潜伏的绿 惊弓之鸟般散开来 上浮,摇摆,沉淀,...
    金指尖的花园阅读 360评论 0 3