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

输入两个链表,找出它们的第一个公共结点。

当不存在公共节点时,返回空节点。

数据范围

链表长度 [1,2000]

保证两个链表不完全相同,即两链表的头结点不相同。

算法思想描述

如上图所示,两种链表的出现的情况只有图中2中,下面我们分别分析
情况1

  1. 令p指针指向链表1,q指针指向链表2,两个链表的公共部分长度为c,链表1的非公共部分为a,链表2的非公共部分为b。
  2. 用指针p遍历链表1,当p遍历到链表尾时,让p指向链表2的头结点,继续向后遍历直到两条链表的第一个公共节点。p走过的路程为 a+b+c。
  3. 指针q同理, 用指针q遍历链表2,当q遍历到链表尾时,让q指向链表1的头结点,继续向后遍历直到两条链表的第一个公共节点。q走过的路程为 b+c+a。
  4. 由2,3得,当指针p与q相遇时,就是两条链表的第一天个公共节点。

情况2

  1. 令p指针指向链表1,q指针指向链表2,链表1的非公共部分为a,链表2的非公共部分为b。
  2. 用指针p遍历链表1,当p遍历到链表尾时,让p指向链表2的头结点,继续向后遍历直到为nullptr。p走过的路程为 a+b。
  3. 指针q同理, 用指针q遍历链表2,当q遍历到链表尾时,让q指向链表1的头结点,继续向后遍历直到为nullptr。q走过的路程为 b+a。
  4. 由2,3得,当指针p与q 都为nullptr时,程序结束。

代码

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    
    ListNode *findFirstCommonNode(ListNode *headA, ListNode *headB) {
        
        ListNode* p = headA;
        ListNode* q = headB;
        
        while(p != q)
        {
            if(p)
            {
                p = p->next;
            }
            else  // p走到了尾
            {
                p = headB;
            }
            
            if(q)
            {
                q = q->next;
            }
            else
            {
                q = headA;
            }
            
        }
        
        return p;
        
    }
};
相关推荐
自我意识的多元宇宙20 小时前
二叉树的遍历和线索二叉树--二叉树的遍历
数据结构
qq_50242899020 小时前
清华大学与微软亚洲研究院出品:Kronos 本地部署教程
数据结构·python·金融量化·kronos开源模型
C雨后彩虹1 天前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_25011 天前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
今天又在写代码1 天前
数据结构v2
数据结构
Rabitebla1 天前
C++ 和 C 语言实现 Stack 对比
c语言·数据结构·c++·算法·排序算法
深邃-1 天前
【数据结构与算法】-顺序表链表经典算法
java·c语言·数据结构·c++·算法·链表·html5
就爱学编程1 天前
惊叹数据结构之美,品味排序算法之妙:对计排、桶排的详细介绍
数据结构·算法·排序算法
努力努力再努力wz1 天前
【MySQL入门系列】掌握表数据的 CRUD:DML 核心语法与执行逻辑解析
android·开发语言·数据结构·数据库·c++·b树·mysql
漂流瓶jz1 天前
UVA-120 煎饼 题解答案代码 算法竞赛入门经典第二版
数据结构·c++·算法·排序·aoapc·算法竞赛入门经典·uva