• acwing 66. 两个链表的第一个公共结点


    地址 https://www.acwing.com/problem/content/description/62/

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

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

    样例

    给出两个链表如下所示:
    A:        a1 → a2
                       ↘
                         c1 → c2 → c3
                       ↗            
    B:     b1 → b2 → b3
    
    输出第一个公共节点c1
    

     

    解法1  

    由于肯定两个链表头有交集

    那么每次移动两个链表头一步,如果移到链表尾则跳转到另一个链表表头继续移动。

    最后相交的位置就是第一个公共节点

    class Solution {
    public:
        ListNode *findFirstCommonNode(ListNode *headA, ListNode *headB) {
            auto p = headA,q = headB;
            while(q != p ){
                if( q) q = q -> next;
                else q = headA;
                if(p ) p = p -> next;
                else p = headB;
            }
            return p ;
        }
    };

    解法2  使用哈希表记录节点 每次移动进行查询 第一个重合的就是公共节点

    /**
     * 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;
            set<ListNode*> sp;
            while(p != NULL){
                sp.insert(p);
                p = p->next;
            }
            p= headB;
            while(p != NULL){
                if(sp.count(p) != 0) return p;
                p = p->next;
            }
            
            return NULL;
        }
    };
    作 者: itdef
    欢迎转帖 请保持文本完整并注明出处
    技术博客 http://www.cnblogs.com/itdef/
    B站算法视频题解
    https://space.bilibili.com/18508846
    qq 151435887
    gitee https://gitee.com/def/
    欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
    如果觉得不错,欢迎点赞,你的鼓励就是我的动力
    阿里打赏 微信打赏
  • 相关阅读:
    产品经理怎么样用图表传达数据信息(多图)
    劣质成本分析(2/3+3/3)
    劣质成本分析(1/3)
    《归来》小诗二首
    减少过程中的浪费(2/2)
    减少过程中的浪费(1/2)
    三种过程分析工具
    必知-网站常用度量指标(2/2)
    必知-网站常用度量指标(1/2)
    产品经理网站数据分析之测量问题现状(四)
  • 原文地址:https://www.cnblogs.com/itdef/p/11443133.html
Copyright © 2020-2023  润新知