1. 程式人生 > >(C++實現)輸入兩個連結串列,找出它們的第一個公共結點

(C++實現)輸入兩個連結串列,找出它們的第一個公共結點

方法一:

先數出兩條連結串列的長度,得到長度差d,先將長連結串列從頭結點往後走d步,之後第二個連結串列從頭開始,兩個連結串列一起一步一步走,直到兩個連結串列的節點第一次相等為止,此時指標位置即為所求。

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

方法二:

用兩個指標同時從兩個連結串列的表頭開始走,當走到自己的連結串列結尾的時候開始從另一個連結串列的表頭開始向後走。終止條件就是兩個指標第一次相遇。此時指標位置即為所求。(兩個連結串列的節點和是一定的,所以兩個指標一定可以同時遍歷完兩條連結串列,即在最後時刻兩個指標一定是重合的)

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