zoukankan      html  css  js  c++  java
  • 两个链表第一个公共点

    题目描述

    输入两个链表,找出它们的第一个公共结点。
     
    思路:用两个指针扫描”两个链表“,最终两个指针到达 null 或者到达公共结点。
     
    代码所基于的想法是,将两个链表L1和L2进行拼接,得到L1+L2和L2+L1两个拼接结果。这两个拼接后的链表长度是一致的,那么逐个判断即可。
     
    /*
    struct ListNode {
    	int val;
    	struct ListNode *next;
    	ListNode(int x) :
    			val(x), next(NULL) {
    	}
    };*/
    class Solution {
    public:
        ListNode* FindFirstCommonNode( ListNode* pHead1, ListNode* pHead2) {
            ListNode *p1=pHead1;
            ListNode *p2=pHead2;
            while(p1!=p2) {
                p1=(p1==NULL ? pHead2:p1->next);
                p2=(p2==NULL ? pHead1: p2->next);
            }
            return p1;
        }
    };
    

    长度相同有公共结点,第一次就遍历到;没有公共结点,走到尾部NULL相遇,返回NULL
    长度不同有公共结点,第一遍差值就出来了,第二遍一起到公共结点;没有公共,一起到结尾NULL。

    /*
    struct ListNode {
        int val;
        struct ListNode *next;
        ListNode(int x) :
                val(x), next(NULL) {
        }
    };*/
    class Solution {
    public:
        ListNode* FindFirstCommonNode( ListNode* pHead1, ListNode* pHead2) {
            ListNode* p=pHead1;
            while(p!=NULL){
                ListNode* q=pHead2;
                while(q!=NULL){
                    if(p==q){
                        return p;
                    }
                    q=q->next;
                }
                p=p->next;
            }
            return p;
        }
    };
    

      

    拥抱明天! 不给自己做枷锁去限制自己。 别让时代的悲哀,成为你人生的悲哀。
  • 相关阅读:
    PAT 乙级真题 1013.组个最小数
    PAT 乙级真题 1012.D进制的A+B
    PAT 乙级真题 1011.个位数统计
    PAT 乙级真题 1010.月饼
    PAT 乙级真题 1009.1019.数字黑洞
    PAT 乙级真题 1008.锤子剪刀布
    PAT 乙级真题 1007.A除以B
    PAT 乙级真题 1006.1016.部分A+B
    C++自定义sort函数
    VS2017如何使用scanf函数
  • 原文地址:https://www.cnblogs.com/dd2hm/p/7395844.html
Copyright © 2011-2022 走看看