面試題 02.07. 鍊錶相交
給定兩個(單向)鍊錶,判定它們是否相交並返回交點。請注意相交的定義基於節點的引用,而不是基於節點的值。換句話說,如果乙個鍊錶的第k個節點與另乙個鍊錶的第j個節點是同一節點(引用完全相同),則這兩個鍊錶相交。
示例 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輸入解釋:相交節點的值為 8 (注意,如果兩個列表相交則不能為 0)。從各自的表頭開始算起,鍊錶 a 為 [4,
1,8,
4,5],鍊錶 b 為 [5,
0,1,
8,4,
5]。在 a 中,相交節點前有 2 個節點;在 b 中,相交節點前有 3 個節點。
示例 2:
輸入:intersectval =
2, lista =[0
,9,1
,2,4
], listb =[3
,2,4
], skipa =
3, skipb =
1輸出:reference of the node with value =
2輸入解釋:相交節點的值為 2 (注意,如果兩個列表相交則不能為 0)。從各自的表頭開始算起,鍊錶 a 為 [0,
9,1,
2,4],鍊錶 b 為 [3,
2,4]。在 a 中,相交節點前有 3 個節點;在 b 中,相交節點前有 1 個節點。
示例 3:
輸入:intersectval =
0, lista =[2
,6,4
], listb =[1
,5], skipa =
3, skipb =
2輸出:null
輸入解釋:從各自的表頭開始算起,鍊錶 a 為 [2,
6,4],鍊錶 b 為 [1,
5]。由於這兩個鍊錶不相交,所以 intersectval 必須為 0,而 skipa 和 skipb 可以是任意值。
解釋:這兩個鍊錶不相交,因此返回 null。
注意:
首先使用unordered_set集合,存放heada鍊錶中所有元素的指標值。
然後遍歷headb鍊錶,找到第乙個與容器中相同的指標值即可返回該節點。未找到則返回null。
class
solution
while
(pb)
pb = pb-
>next;
}return
null;}
};
時間複雜度: o(n)
空間複雜度: o(n)
如果兩個鍊錶的長度相等,那麼我們可以同時遍歷兩個鍊錶,當兩個節點相等時,即為相交節點。
所以我們需要遍歷求出兩個鍊錶的長度,然後較長的鍊錶移動它們的長度差,再同步遍歷比較就可以了,**如下:
class
solution
while
(pb)
int diff =
abs(lena - lenb);if
(lena > lenb)
}else
}while
(heada && headb)
heada = heada-
>next;
headb = headb-
>next;
}return
null;}
};
時間複雜度: o(n)
空間複雜度: o(1)
與網上的**一致。
class
solution
while
(pb)
int diff =
abs(lena - lenb);if
(lena > lenb)
}else
}while
(heada && headb)
heada = heada-
>next;
headb = headb-
>next;
}return
null;}
};
時間複雜度: o(n)
空間複雜度: o(1)
LeeCode 面試02 07 鍊錶相交
給定兩個 單向 鍊錶,判定它們是否相交並返回交點。請注意相交的定義基於節點的引用,而不是基於節點的值。換句話說,如果乙個鍊錶的第k個節點與另乙個鍊錶的第j個節點是同一節點 引用完全相同 則這兩個鍊錶相交。示例 1 輸入 intersectval 8,lista 4,1,8,4,5 listb 5,0...
面試題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輸入解釋 相交節點的值為 ...
面試題 02 07 鍊錶相交
題目鏈結 給定兩個 單向 鍊錶,判定它們是否相交並返回交點。請注意相交的定義基於節點的引用,而不是基於節點的值。換句話說,如果乙個鍊錶的第k個節點與另乙個鍊錶的第j個節點是同一節點 引用完全相同 則這兩個鍊錶相交。示例 1 輸入 intersectval 8,lista 4,1,8,4,5 list...