双向链表的相关操作

双向链表

简介:双向链表是包含向前指针的单链表,可以向前向后查找;单链表删除时需要借助辅助节点temp,而双向链表可以自我删除

双向链表的应用实例

  1. 遍历:和单链表相同,只是可以向前,也能向后;
  2. 添加:默认添加到链表最后;
    • 先找到最后一个节点
    • temp.next = newNode;
    • newNode.pre = temp;
    public void add(HeroNode2 heroNode){
        //因为head节点不能动,需要一个辅助变量遍历temp
        HeroNode2 temp = head;
        while(true){
            //找到链表的最后
            if(temp.next==null){
                break;
            }
            temp = temp.next;
        }
        //将最后一个节点的next指向新的节点
        temp.next = heroNode;
        heroNode.pre = temp;
    }

​ 按照顺序添加:可以画图辅助理解:

public void addByOrder(HeroNode2 heroNode){
        HeroNode2 temp = head;
        boolean flag = false;
        while(true){
            if(temp.next==null){
                break;
            }
            if(temp.next.no>heroNode.no){
                break;
            }
            if(temp.no==heroNode.no){
                flag = true;
                break;
            }
            temp = temp.next;
        }
        if(flag){
            System.out.printf("准备插入编号%d的已经存在,不能加入",heroNode.no);
        }
        else{
            //注意赋值的顺序
            heroNode.next = temp.next;
            heroNode.pre = temp;
            temp.next = heroNode;
            temp.next.pre =heroNode;
        }
    }
  1. 修改:和单链表相同;
  2. 删除:可以自我删除
    • temp.pre.next =temp.next;
    • temp.next.pre=temp.pre;
    • 删除时要注意删的节点是不是最后一个节点。
public void delete(int no){
        if (head.next == null) {
            System.out.println("链表为空");
            return;
        }
        HeroNode2 temp = head.next;
        boolean flag = false;
        while(true){
            if(temp==null){
                break;
            }
            if(temp.next.no==no){
                temp.pre.next =temp.next;
                //如果是最后一个节点就不需要执行下面一句话,否则会出现空指针异常
                if (temp.next!=null) {
                    temp.next.pre = temp.pre;
                }
                flag = true;
                System.out.println("删除成功");
                break;
            }
            temp = temp.next;
        }
        if(!flag){
            System.out.println("该节点不存在,无法删除");
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值