题解 | #两个链表的第一个公共结点#

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

https://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46

import java.util.*;
/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class Solution {
    public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
	  //大体思路:利用总路程相等的思想。双指针法,两个指针同时向前走,如果为空,就走另一条链表,当两个指针相同时,就结束循环。返回
        ListNode p1,p2;
	  //这里 的双指针不能用参数去替代,如果用参数去替代的话,会造成链表头节点的丢失。走不到另一条链表上。
        p1=pHead1;
        p2=pHead2;
        while(p1!=p2){
            if(p1==null){
                p1=pHead2;
            }else{
                p1=p1.next;
            }
            if(p2==null){
                p2=pHead1;
            }else{
                p2=p2.next;
            }
        }
       return p1;
    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
03-18 14:29
牛客604067584号:感觉算法卷的人少很多,毕竟只有一部分bg还不错的硕士才会考虑算法,虽然hc不如后端,但是竞争真的少很多。
点赞 评论 收藏
分享
运营3年修炼中接简历辅导:你的科研项目经历里,只写了你的动作,没有写你的思考和成果,不要只写使用什么进行了什么,这等于罗列你的任务,简历是为了突出你的优秀,你在什么样的任务背景下,克服了什么样的困难,针对性地做了哪些事情,最后达成了什么成果(用数据体现你的成果和效率)
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务