//不考慮帶環的情況
將他們長度統一,判斷是否有公共結點
elemsn *thesamenode(elemsn *head1,elemsn *head2)
for(int i=0;inext,i++);//在長鏈上移動指標p,統一長度
for(;p&&q&&p-q;p=p->next,q=q->next);//判斷是否有交點
return p;//沒找到返回null,找到返回第乙個公共結點的位址
}
//設定崗哨,跑到崗哨前面停,然後崗哨後移
//無論有無交點都相當於有交點,無相當於交於null,有則返回
elemsn *thesamenode(elemsn *head1,elemsn *head2)
return end1->next;
}
判斷兩個鍊錶是否相交
思路1 最暴力的辦法,針對鍊錶1的每乙個節點,判斷其是否也在鍊錶2中,複雜度o n m 明顯不是乙個好方法。思路2 給每個節點增加乙個標記量,可以是附在鍊錶中的成員,也可以是另外的乙個結構,例如用乙個陣列來儲存。先遍歷鍊錶1,標記出遍歷過的節點,再遍歷鍊錶2,如果發現某個節點已經被遍歷過,則說明相交...
判斷兩個鍊錶是否相交
參考 判斷兩個鍊錶是否相交 假設兩個鍊錶都沒有環 有以下三種方法 1 判斷第乙個鍊錶的每個節點是否在第二個鍊錶中 2 把第二個鍊錶連線到第乙個後面,判斷得到的鍊錶是否有環,有環則相交 3 先遍歷第乙個鍊錶,記住最後乙個節點,再遍歷第二個鍊錶,得到最後乙個節點時和第乙個鍊錶的最後乙個節點做比較,如果相...
判斷兩個鍊錶是否相交
判斷兩個鍊錶是否相交,程式設計之美 給出了以下方法 1.判斷第乙個鍊錶的每個節點是否在第二個鍊錶中,這種方法的時間複雜度為 o length h1 length h2 這種方法很耗時間 2.利用計數的方法 乙個簡單的做法是對第乙個鍊錶的結點位址進行hash排序,建立hash表,然後針對第二個鍊錶的每...