内部类实现双向链表

  • 链表:

单向链表:只能从头遍历到尾或从尾遍历到头

双向链表:既可以从头遍历到尾,也可以从尾遍历到头

PS:环形链表:有向无环图(寻路算法)

  • 内部类模拟双向链表的实现:
/**
 * Prudence 2019/6/21 17:25
 */
public class MyLinkedList {
    private Node first;//链表中第一个节点
    private Node last;//链表中最后一个节点
    private int size;//节点的数量

    //节点
    class Node{
        Node prev;//上一个节点对象
        Node next;//下一个节点对象
        Object ele;//当前节点元素
        //创建节点并赋值
        public Node(Object ele){
            this.ele = ele;
        }
    }

    //添加数据到第一位
    public void addFirst(Object ele){
        Node node = new Node(ele);//节点对象
        //如果当前节点是第一次添加(当前节点即使开头也是结尾)
        if(size == 0){
            this.first = node;
            this.last = node;
        } else {
            //新节点的下一位是原有的节点
            node.next = this.first;
            //把新增节点作为原有节点之前的一个节点,即第一个节点
            this.first.prev = node;
            //更新新节点为开始节点
            this.first = node;
        }
        size++;
    }

    //添加最后一位
    public void addLast(Object ele){
        //创建节点
        Node node = new Node(ele);
        if(size == 0){
            this.first = node;
            this.last = node;
        } else {
            //当前节点的下一位是新的节点
            this.last.next = node;
            //新节点的上一位是原有节点
            node.prev = this.last;
            //更新新节点为下一个节点
            this.last = node;
        }
    }

    @Override
    public String toString() {
        if(size == 0){
            return "[]";
        }
        StringBuffer sbr = new StringBuffer();
        //获取第一个节点
        Node first = this.first;
        sbr.append("[");
        for (int i = 0; i < size; i++) {
            sbr.append(first.ele);
            if(i != size - 1){
                sbr.append(",");
            } else {
                sbr.append("]");
            }
            first = first.next;//获取下一个节点
        }
        return sbr.toString();
    }

    //删除节点
    public void remove(Object ele){
        //找到要删除的节点
        Node first = this.first;
        for (int i = 0; i < size; i++) {
            if(!first.ele.equals(ele)){
                if(first.next == null){
                    return;
                }
                first = first.next;
            }
        }
        //删除节点
        if(first == this.first){
            this.first = first.next;
            this.first.prev = null;
        } else if(first == last){
            this.last = first.prev;
            this.last.next = null;
        } else {
            //把删除节点的上一个节点连接删除节点的下一个节点
            first.prev.next = first.next;
            //把删除节点的下一个节点连接删除节点的上一个节点
            first.next.prev =first.prev;
        }
        size--;
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值