資料結構——雙向連結串列

lippon發表於2020-10-26

普通連結串列的節點由節點值和指向下一個節點的指標組成。雙向連結串列顧名思義,節點中多一個指標可以指向前一個節點。
優點:可以得到前節點,這樣在只有當前節點的情況下,可以刪除本節點。

class Node {
    public int val;
    public Node next, prev;
    public Node(int v) {
        this.val = v;
    }
}

class DoubleList {  
    private Node head, tail; // 頭尾虛節點
    private int size; // 連結串列元素數

    public DoubleList() {
        head = new Node(0);
        tail = new Node(0);
        head.next = tail;
        tail.prev = head;
        size = 0;
    }

    // 在連結串列頭部新增節點 x
    public void addFirst(Node x) {
        x.next = head.next;
        x.prev = head;
        head.next.prev = x;
        head.next = x;
        size++;
    }

    // 刪除連結串列中的 x 節點(x 一定存在)
    public void remove(Node x) {
        x.prev.next = x.next;
        x.next.prev = x.prev;
        size--;
    }
    
    // 刪除連結串列中最後一個節點,並返回該節點
    public Node removeLast() {
        if (tail.prev == head)
            return null;
         Node last = tail.prev;
        remove(last);
        return last;
    }
    
    // 返回連結串列長度
    public int size() { return size; }
}

相關文章