两个链表的第一个公共节点

package com.dugstudio.SwordToOfferBook.Singleton.Interview;

/**
 * @Author JH
 * @CreateDate 18-6-10
 * @Description 两个链表的第一个公共节点
 */
public class FindFirstCommonNode {
    public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
        if (pHead1==null||pHead2==null)return null;
        ListNode p1=pHead1,p2=pHead2;
        int len1=0,len2=0;
        //计算p1的长度
        while (p1!=null){
            len1++;
            p1=p1.next;
        }
        //计算p2的长度
        while (p2!=null){
            len2++;
            p2=p2.next;
        }
        int i=len1-len2;
        p1=pHead1;
        p2=pHead2;
        //让常德链表先走i步 这样他们就是同步的
        if (i>0){
            while (i>0){
                p1=p1.next;
                i--;
            }

        }else{
            while (i<0){
                p2=p2.next;
                i++;
            }
        }
        //遍历直到两个节点相等
        while (p1!=null||p2!=null){
            if (p1==p2)return p1;
            p1=p1.next;
            p2=p2.next;
        }
        return null;
    }

    public static void main(String[] args) {
        ListNode l1=new ListNode(1);
        ListNode l2=new ListNode(2);
        ListNode l3=new ListNode(3);
        ListNode l4=new ListNode(4);
        ListNode l5=new ListNode(5);
        ListNode l6=new ListNode(6);
        ListNode l7=new ListNode(7);
        l1.next=l2;
        l2.next=l3;
        l3.next=l4;
        l4.next=l6;
        l5.next=l6;
        l6.next=l7;
        FindFirstCommonNode f=new FindFirstCommonNode();
        f.FindFirstCommonNode(l1,l5);

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值