02 07 鍊錶相交

2021-10-10 08:15:38 字數 2365 閱讀 5547

面試題 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...