找出两个链表的交叉点

该程序旨在找到两个单链表的交叉起点,如果不存在交叉则返回null。需保持链表原有结构,且无环。高效解法是从未知交叉点的尾节点开始反向搜索,但单链表无法实现。考虑两种方案:1.暴力遍历所有节点;2.将链表尾部对齐,从较短链表开始找交叉点,时间复杂度为O(n),但需额外计算链表长度。
摘要由CSDN通过智能技术生成

请写一个程序,找到两个单链表最开始的交叉节点。
注意事项
如果两个链表没有交叉,返回null。
在返回结果后,两个链表仍须保持原有的结构。
可假定整个链表结构中没有循环。

样例
下列两个链表:
A: a1 → a2
     ↘
       c1 → c2 → c3
       ↗
B: b1 → b2 → b3
在节点 c1 开始交叉。

  最高效最优的方法就是从尾结点开始往前找交叉点,对于单链表来说这种方法是无法实现的.

有两种可行的方案
1.暴力搜索,直接比对所有结点,直到找出交叉点
2.将两个链表尾对齐,然后从较短的那条链开始寻找交叉点,可以做到的是找交叉点的时间复杂度为o(n),但是需要花额外的时间去求链表的长度

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;      
 *     }
 * }
 */
public class Solution {
   
    /**
     *
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值