刪除連結串列中的節點
阿新 • • 發佈:2020-12-02
1.問題描述
請編寫一個函式,使其可以刪除某個連結串列中給定的(非末尾)節點。傳入函式的唯一引數為 要被刪除的節點 。
現有一個連結串列 -- 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.
提示:
- 連結串列至少包含兩個節點。
- 連結串列中所有節點的值都是唯一的。
- 給定的節點為非末尾節點並且一定是連結串列中的一個有效節點。
- 不要從你的函式中返回任何結果。
2.求解
與下一個節點交換
- 我們常用的刪除連結串列節點的方法是拿到刪除節點的前一個next指標,使其指向刪除節點之後的節點
- 但是在本題中,無法得到刪除節點之前的指標嗎,於是我們可以將刪除節點替換成其後面節點的值,然後刪除後面的節點
程式碼如下
/* 執行用時:0 ms, 在所有 Java 提交中擊敗了100.00% 的使用者 記憶體消耗:38 MB, 在所有 Java 提交中擊敗了67.71% 的使用者 */ public void deleteNode(ListNode node) { node.val = node.next.val; node.next = node.next.next; }