力扣237 刪除鍊錶中的節點(與下乙個節點交換)

2021-10-20 19:47:57 字數 1377 閱讀 3878

力扣237. 刪除鍊錶中的節點(與下乙個節點交換)

請編寫乙個函式,使其可以刪除某個鍊錶中給定的(非末尾)節點。傳入函式的唯一引數為 要被刪除的節點 。

現有乙個鍊錶 -- head = [4,5,1,9],它可以表示為:

示例 1:

輸入:head = [4,5,1,9], node = 5

輸出:[4,1,9]

解釋:給定你鍊錶中值為 5 的第二個節點,那麼在呼叫了你的函式之後,該鍊錶應變為 4 -> 1 -> 9.

示例 2:

輸入:head = [4,5,1,9], node = 1

輸出:[4,5,9]

解釋:給定你鍊錶中值為 1 的第三個節點,那麼在呼叫了你的函式之後,該鍊錶應變為 4 -> 5 -> 9.

鍊錶至少包含兩個節點。

鍊錶中所有節點的值都是唯一的。

給定的節點為非末尾節點並且一定是鍊錶中的乙個有效節點。

不要從你的函式中返回任何結果。

如果我們要在鍊錶中刪除乙個節點,一般的操作是:

修改要刪除節點的上乙個節點的指標

將該指標指向要刪除節點的下乙個節點

例如,在鍊錶 [4, 5, 1, 9] 中,當我們要刪除節點 5 時,我們會修改節點 5 上乙個節點 4 的指標,讓它指向節點 5 的下乙個節點,即節點 1:

但這道題只告訴我們要刪除的節點,我們並不知道該節點的上乙個節點是什麼,這時候又該如何是好呢?

既然我們要刪除乙個節點時需要知道它的上乙個節點,如果我們無法得知上乙個節點,我們就 找乙個可以知道上乙個節點的節點,把它變成要刪除的節點,然後刪除它。

這樣聽起來好像有些拗口?沒事,直接看乙個例子!

還是 [4, 5, 1, 9] 鍊錶,還是刪除節點 5。

這樣一來,第二個節點 1 和第三個節點 1,無論我們刪除其中的哪乙個,都可以得到最終結果 [4, 1, 9]。既然第二個節點不好刪除,那我們就果斷刪除第三個啦~

改變第二個節點 1 的指標,將它指向第 4 個節點 9,這樣一來,第三個節點 1 就被刪除了。

時間和空間複雜度都是:o(1)o(1)。

class solution 

};

力扣 刪除鍊錶中的節點

編寫乙個函式,使其可以刪除某個鍊錶中給定的 非末尾 節點,你將只被給定要求被刪除的節點。示例 現有乙個鍊錶 head 4,5,1,9 它可以表示為 輸入 head 4,5,1,9 node 5 輸出 4,1,9 解釋 給定你鍊錶中值為 5 的第二個節點,那麼在呼叫了你的函式之後,該鍊錶應變為 4 1...

237 刪除鍊錶中的節點

請編寫乙個函式,使其可以刪除某個鍊錶中給定的 非末尾 節點,你將只被給定要求被刪除的節點。現有乙個鍊錶 head 4,5,1,9 它可以表示為 4 5 1 9示例 1 輸入 head 4,5,1,9 node 5 輸出 4,1,9 解釋 給定你鍊錶中值為 5 的第二個節點,那麼在呼叫了你的函式之後,...

237 刪除鍊錶中的節點

請編寫乙個函式,使其可以刪除某個鍊錶中給定的 非末尾 節點,你將只被給定要求被刪除的節點。現有乙個鍊錶 head 4,5,1,9 它可以表示為 示例 1 輸入 head 4,5,1,9 node 5 輸出 4,1,9 解釋 給定你鍊錶中值為 5 的第二個節點,那麼在呼叫了你的函式之後,該鍊錶應變為 ...