力扣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 的第二個節點,那麼在呼叫了你的函式之後,該鍊錶應變為 ...