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

时间:2021-02-14 11:05:20

分析:公共结点是地址相同的两个结点,也就是同一个结点,由于是单向链表,所有从公共结点之后两链表重合,其拓扑结构为Y型。例如:链表一:3,5,7,4;链表二:1,6,5,7,4;从元素5开始两个链表开始重合,两个链表尾部重合

方法一:先计算两个链表的长度,计算两个链表的长度差,让较长的链表先走,直到与较短链表一样的长度,然后二者同时移动,找出首次相同的元素(地址相同

/*
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;
        int diff=0,len1=0,len2=0;
        while(p1)
        {
            p1=p1->next;
            len1++;
        }
        while(p2)
        {
            p2=p2->next;
            len2++;
        }
        if(len1>len2)
        {
            diff=len1-len2;
            p1=pHead1;
            p2=pHead2;
        }
        else
        {
            diff=len2-len1;
            p1=pHead2;
            p2=pHead1;
        }
        for(int i=0;i<diff;i++)
            p1=p1->next;
        while(p1&&p2)
        {
            if(p1==p2)
                break;
            p1=p1->next;
            p2=p2->next;
        }
        return p1;
        
    }
};

方法二:设置两个指针分别指向两个链表,指向长链表的指针走完,指向短链表;指向短链表的指针走完,指向长链表;第二遍走的时候,一定会在交点相遇

/*
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;
    }
};