请写一个程序,找到两个单链表最开始的交叉节点。
注意事项
如果两个链表没有交叉,返回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 {
/**
* @param headA: the first

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

被折叠的 条评论
为什么被折叠?



