1. 程式人生 > 實用技巧 >刪除連結串列中的節點

刪除連結串列中的節點

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;
    }