Java数据结构 - 双向循环链表

class DoubleLoopNode {
    // 上一个节点
    DoubleLoopNode pre;
    // 下一个节点
    DoubleLoopNode next;
    // 节点的内容
    int data;

    public DoubleLoopNode(int value) {
        this.pre = this;
        this.next = this;
        this.data = value;
    }

    // 插入节点
    public void append(DoubleLoopNode node) {
        // 原来的下一个节点
        DoubleLoopNode nextNode = this.next;
        // 把新节点作为当前节点的下一个节点
        this.next = node;
        // 把当前节点作为新节点的前一个节点
        node.pre = this;
        // 让原来的下一个节点作为新节点的下一个节点
        node.next = nextNode;
        // 让原来的下一个节点的上一个节点为新节点
        nextNode.pre = node;
    }

    // 获取下一个节点
    public DoubleLoopNode next() {
        return this.next;
    }

    // 获取上一个节点
    public DoubleLoopNode pre() {
        return this.pre;
    }

    // 获取数据
    public int getData() {
        return this.data;
    }
}

public class Main {
    public static void main(String[] args) {
        // 创建节点
        DoubleLoopNode dln1 = new DoubleLoopNode(1);
        DoubleLoopNode dln2 = new DoubleLoopNode(2);
        DoubleLoopNode dln3 = new DoubleLoopNode(3);

        // 追加节点
        dln1.append(dln2);
        dln2.append(dln3);

        // 查看所有节点
        System.out.println(dln2.pre().getData());
        System.out.println(dln2.getData());
        System.out.println(dln2.next().getData());
    }
}

 

posted @ 2019-09-27 10:09  Qi-BJ  阅读(212)  评论(0编辑  收藏  举报