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

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

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

struct ListNode *FindFirstCommonNode(struct ListNode* pHead1, struct ListNode* pHead2 ) {
    //分别为两个链表分配两个指针来存放头节点;
    struct ListNode *p = pHead1;
    struct ListNode *p = pHead2;
    //设置一个循环判断————直到两个指针中存放的内容完全相同时,即循环结束。
    while(p!=q){
        //第一个链表上的指针顺着链表的方向依次后移直到为空时,将头节点赋给这个指针。
        if(p)
            p = p->next;
        else p = pHead;//这里注意一定要添加else,因为如果不添加程序会依次往后执行导致进入死循环。
        //同理这样判断第二个链表上的指针。
        if(q)
            q = q->next;
        else q = pHead2;
    }
    return p;//这里无论是返回p还是q都可以。
    }
该题利用同步循环移位的方法可以解决,因为如果两个链表长度要么相同,此时两个指针以相同的速度会在一开始就会相遇,路程也是完全相同的。如果两个链表长度不相同,那么一定是前面不同,此时分别进入循环移位状态,当指针移到空时则重新将头节点赋给该指针,依次进行下去直到两者相等时则循环结束,返回该节点。如下表所示最后会在6相遇。
1
4
2 5
3 6
6 7
7 4
1 5
2 6
3 7
6 4
7 5
1 6
2 7
3 4
6 5
7 6
1 7
2 4
3 5
6 6

全部评论

相关推荐

程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务