每日leetcode 刪除鍊錶中的節點

2021-08-28 18:21:41 字數 851 閱讀 6869

請編寫乙個函式,使其可以刪除某個鍊錶中給定的(非末尾)節點,你將只被給定要求被刪除的節點。

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

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.

說明:鍊錶至少包含兩個節點。

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

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

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

——————————————————————————————————————

語言:c++

思路:看到這題一開始還覺得為什麼要考呢,不就是普通的刪除嗎?後來一看**,就給了乙個要刪除的節點,當時就蒙了。。。這怎麼知道它的前驅呢?後來查了之後才發現思路很巧妙,就是讓它跟它後邊的值一樣,然後把它後邊的給刪了,例如12345,要刪除3,就把它變成12445,然後刪掉後邊的4,就成了1245

/**

* definition for singly-linked list.

* struct listnode

* };

*/class solution

};

每日leetcode 排序鍊錶

在 o n log n 時間複雜度和常數級空間複雜度下,對鍊錶進行排序。示例 1 輸入 4 2 1 3 輸出 1 2 3 4 示例 2 輸入 1 5 3 4 0 輸出 1 0 3 4 5 採用歸併排序,將陣列換成鍊錶即可 definition for singly linked list.struc...

每日leetcode 奇偶鍊錶

給定乙個單鏈表,把所有的奇數節點和偶數節點分別排在一起。請注意,這裡的奇數節點和偶數節點指的是節點編號的奇偶性,而不是節點的值的奇偶性。請嘗試使用原地演算法完成。你的演算法的空間複雜度應為 o 1 時間複雜度應為 o nodes nodes 為節點總數。示例 1 輸入 1 2 3 4 5 null ...

LeetCode 刪除鍊錶中的節點

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