LeetCode 面試題 02 07 鍊錶相交

2021-10-08 17:09:22 字數 1271 閱讀 4354

給定兩個(單向)鍊錶,判定它們是否相交並返回交點。請注意相交的定義基於節點的引用,而不是基於節點的值。換句話說,如果乙個鍊錶的第k個節點與另乙個鍊錶的第j個節點是同一節點(引用完全相同),則這兩個鍊錶相交。

輸入:intersectval = 8, lista = [4,1,8,4,5], listb = [5,0,1,8,4,5], skipa = 2, skipb = 3

輸出:reference of the node with value = 8

輸入解釋:相交節點的值為 8 (注意,如果兩個列表相交則不能為 0)。從各自的表頭開始算起,鍊錶 a 為 [4,1,8,4,5],鍊錶 b 為 [5,0,1,8,4,5]。在 a 中,相交節點前有 2 個節點;在 b 中,相交節點前有 3 個節點。

解題思路:

1.指標p1遍歷鍊錶heada,指標p2遍歷鍊錶headb

2.p1再從headb開始遍歷,p2再從heada開始遍歷

3.如果有交點d,那麼在到達d點時,p1路程s1:ad+dc+bd;p2路程s2:bd+dc+ad。必有s1=s2,雙指標相交,若無交點d,最終p1=p2=null

解題思路:

1.計算兩鍊錶長度

2.擷取長鍊表頭部多餘部分,使兩鍊錶長度相同

3.同時遍歷兩個鍊錶,尋找交點

/**

* definition for singly-linked list.

* struct listnode

* };

*/class solution

}else

}//遍歷鍊錶,尋找交點

while (heada != headb)

return heada;}};

leetcode 面試題 02 07 鍊錶相交

面試題 02.07.鍊錶相交 給定兩個 單向 鍊錶,判定它們是否相交並返回交點。請注意相交的定義基於節點的引用,而不是基於節點的值。換句話說,如果乙個鍊錶的第k個節點與另乙個鍊錶的第j個節點是同一節點 引用完全相同 則這兩個鍊錶相交。示例 1 輸入 intersectval 8,lista 4,1,...

leetcode 面試題 02 07 鍊錶相交

題目 給定兩個 單向 鍊錶,判定它們是否相交並返回交點。請注意相交的定義基於節點的引用,而不是基於節點的值。換句話說,如果乙個鍊錶的第k個節點與另乙個鍊錶的第j個節點是同一節點 引用完全相同 則這兩個鍊錶相交。示例 輸入 intersectval 8,lista 4,1,8,4,5 listb 5,...

面試題02 07 鍊錶相交

題目大概練過leetcode的鍊錶部分估計都做過這道題 示例 1 輸入 intersectval 8,lista 4,1,8,4,5 listb 5,0,1,8,4,5 skipa 2,skipb 3輸出 reference of the node with value 8輸入解釋 相交節點的值為 ...