相交链表

编写一个程序,找到两个单链表相交的起始节点。

如下面的两个链表:
在这里插入图片描述

思路:
  假设链表A的长度为a,链表B的长度为b,相交后的链表长度为c。初始化pa、pb两个工作指针分别为A、B链表的头节点,分别遍历链表,当遍历到C链表尾部时,再分别赋值pa=B链表头节点,pb=A链表头节点。如若两个链表相交则终会有一刻两工作指针指向同一结点。这是为什么呢?可以作如下思考:相交则有a+c+b+c=b+c+a+c,不相交则有a+b=b+a(c=0)。实际上是补齐了两工作指针走过的路程。与之前环形链表套圈的思维相似。

public class Solution {
    public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
        if(headA==null||headB==null)
            return null;
        ListNode p1=headA;
        ListNode p2=headB;
        while(p1!=p2){
            p1=p1==null?p1=headB:p1.next;
            p2=p2==null?p2=headA:p2.next;
        }
        return p1;
    }
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值