溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

無頭雙向鏈表的實(shí)現(xiàn)

發(fā)布時(shí)間:2020-07-19 05:05:19 來源:網(wǎng)絡(luò) 閱讀:192 作者:Linnnna 欄目:編程語言

無頭雙向鏈表的實(shí)現(xiàn)

1.頭插法

public void addFirst(int data) {  //頭插
        DLinkedNode newNode = new DLinkedNode(data);//加入的新節(jié)點(diǎn)
        DLinkedNode next = head.next;
        newNode.next = next;
        next.prev = newNode;
        head.next = newNode;
        newNode.prev = head;
    }

2.尾插法

public void addLast(int data) {//尾插
        DLinkedNode newNode = new DLinkedNode(data);//新插入的節(jié)點(diǎn)
        DLinkedNode prev = head.prev;
        newNode.next = head;
        head.prev = newNode;
        newNode.prev = prev;
        prev.next = newNode;
    }

3.任意位置插入,第一個(gè)數(shù)據(jù)節(jié)點(diǎn)為0號(hào)下標(biāo)

public void addIndex(int index,int data) {//任意位置插入
        int size = size();
        if(index < 0 || index > size){
            return;
        }
        if(index == 0){
            addFirst(data);
            return;
        }
        if(index == size) {
            addLast(data);
            return;
        }
        DLinkedNode next = getPos(index);
        DLinkedNode prev = next.prev;
        DLinkedNode newNode = new DLinkedNode(data);
        prev.next = newNode;
        newNode.prev = prev;
        next.prev = newNode;
        newNode.next = next;
    }

這里用到的計(jì)算鏈表長度的方法:

public int size(){
        int size = 0;
        for(DLinkedNode cur = head.next; cur != head; cur = cur.next) {
            size++;
        }
        return size;
    }

和查找鏈表中某一位置的方法:

public DLinkedNode getPos(int index) {
        DLinkedNode cur = head.next;
        for(int i = 0; i < index; i++){
            cur = cur.next;
        }
        return cur;
    }

4.查找是否包含關(guān)鍵字key是否在鏈表當(dāng)中

public boolean contains(int key) {//查找是否包含關(guān)鍵字key的節(jié)點(diǎn)
        for(DLinkedNode cur = head.next; cur != head; cur = cur.next) {
            if(cur.val == key){
                return true;
            }
        }
        return false;
    }

5.刪除第一次出現(xiàn)關(guān)鍵字為key的節(jié)點(diǎn)

public void remove(int key){
        DLinkedNode toRemove = find(key);
        if(toRemove == null) {
            return;
        }
        DLinkedNode prev = toRemove.prev;
        DLinkedNode next = toRemove.next;
        prev.next = next;
        next.prev = prev;
    }

這里用到查找關(guān)鍵字key在鏈表中的位置的方法:

public DLinkedNode find(int key) {
        for(DLinkedNode cur = head.next; cur != head; cur = cur.next) {
            if(cur.val == key){
                return cur;
            }
        }
        return null;
    }

6.刪除所有值為key的節(jié)點(diǎn)

public void removeAll(int key){
        while (true){
            DLinkedNode toRmove = find(key);
            if(toRmove == null){
                return;
            }
            DLinkedNode prev = toRmove.prev;
            DLinkedNode next = toRmove.next;
            prev.next = next;
            next.prev = prev;
        }
    }

7.打印鏈表

public void display(){
        System.out.print("正向:[");
        for(DLinkedNode cur = head.next; cur != head; cur = cur.next){
            System.out.print(cur.val);
            if(cur.next != head){
                System.out.print(",");
            }
        }
        System.out.println("]");
        System.out.println("反向:[");
        for(DLinkedNode cur = head.prev; cur != head; cur = cur.prev){
            System.out.print(cur.val);
            if(cur.prev != head){
                System.out.print(",");
            }
        }
        System.out.println("]");
    }

8.清空鏈表

public void clear(){
        head.next = head;
        head.prev = head;
    }
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI