简单的双向循环列表

/**
 * @Description 实现一个简单的双向循环列表 在改列表中,每个node都会记录前一个元素和后一个元素的地址
 * @auther Eleven
 * @create 2020-04-03 23:08
 **/
public class DoubleLoopNode {
    //记录前一个元素
    DoubleLoopNode pre;
    //记录下一个元素
    DoubleLoopNode next;
    //数据
    int data;

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

    //往链表中加入一个node
    public void after(DoubleLoopNode doubleLoopNode){
        //首先获取当前node的下一个元素的地址
        DoubleLoopNode next = this.next;
        //设置下一个node的前一个地址为新增的元素
        next.pre = doubleLoopNode;
        //设置新增元素的下一个元素为上面的next
        doubleLoopNode.next = next;
        //设置当前元素的下一个元素为新增的元素
        this.next = doubleLoopNode;
        //设置新增元素的上一个元素为当前元素
        doubleLoopNode.pre=this;
    }

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

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

    //获取上一个元素
    public DoubleLoopNode pre(){
        return this.pre;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值