• 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驱动爱好者 服务器程序员沟通交流
    如果觉得不错,欢迎点赞,你的鼓励就是我的动力
    阿里打赏 微信打赏
  • 相关阅读:
    centos ftp搭建
    python_模块
    python_如何建立包
    python_类
    python_递归
    python_函数
    python_字典
    python_条件、循环语句
    python_中文乱码问题
    Viola–Jones object detection framework--Rapid Object Detection using a Boosted Cascade of Simple Features中文翻译 及 matlab实现(见文末链接)
  • 原文地址:https://www.cnblogs.com/itdef/p/11443133.html
Copyright © 2020-2023  润新知