160 相交链表

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。

图示两个链表在节点 c1 开始相交:

题目数据 保证 整个链式结构中不存在环。

注意,函数返回结果后,链表必须 保持其原始结构 。

力扣解答

1穷举法

2如果用哈希表的话 时间复杂度为O(m+n) 空间复杂度为O(m)或O(n)

判断两个链表是否相交,可以使用哈希集合存储链表节点。

首先遍历链表 \textit{headA}headA,并将链表 \textit{headA}headA 中的每个节点加入哈希集合中。然后遍历链表 \textit{headB}headB,对于遍历到的每个节点,判断该节点是否在哈希集合中:

如果当前节点不在哈希集合中,则继续遍历下一个节点;

如果当前节点在哈希集合中,则后面的节点都在哈希集合中,即从当前节点开始的所有节点都在两个链表的相交部分,因此在链表 \textit{headB}headB 中遍历到的第一个在哈希集合中的节点就是两个链表相交的节点,返回该节点。

public class Solution{
   public ListNode getIntersectionNode(ListNode headA,ListNode headB) {
       Set<ListNode>Visited=new HashSst<ListNode>();
       ListNode temp =headA;
       while(temp!=null) {
         visited.add(temp);
         temp=temp.next;
       }
        temp=headB;
        while(temp!=null) {
       if (visited.contains(temp)) {
          return temp;
        }
        temp=temp.next;
       }
        return null;
    }
}

3使用双指针:当两个指针指向同一个的时候,即为所求。

4或者 先遍历两个链表,然后用m-n。然后长的从m-n位置开始,短的从初始位置开始,遍历直到指向同一个节点。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值