手写双向链表,增删改查

package shuJuJieGouYuSuanFa.lianBiao;

/**
 * @ClassName DoubleLinkedList
 * @Author 瞿肖
 * @Date 2022/7/23 19:32
 */
public class DoubleLinkedList {
    public static void main(String[] args) {
        LinkedList ls = new LinkedList();
        DoubleHeroNode d1 = new DoubleHeroNode(1, "零从", "豹子头");
        DoubleHeroNode d2 = new DoubleHeroNode(2, "松江", "及时雨");
        DoubleHeroNode d3 = new DoubleHeroNode(3, "武松", "打虎英雄");
        DoubleHeroNode d4 = new DoubleHeroNode(3, "那你爹", "不知名的小卒");
        ls.add(d1);
        ls.add(d2);
        ls.add(d3);
        ls.list(ls.getHead());
        ls.update(d4);
        System.out.println("************");
        ls.list(ls.getHead());
    }
}

class LinkedList {
    private DoubleHeroNode head = new DoubleHeroNode(0, "", "");

    public DoubleHeroNode getHead() {
        return head;
    }

    //遍历双向链表
    public void list(DoubleHeroNode head) {
        DoubleHeroNode t = head.next;
        if (t == null) {
            System.out.println("双向链表为空!");
            return;
        }

        while (true) {
            if (t == null) {
                return;
            }
            System.out.println(t);
            t = t.next;
        }
    }

    /**
     * 被删除元素前一位元素的next指向被删的next
     * 被删除的后一位元素的pre指向被删除的pre
     *
     * @param no 被删的序号
     */
    public void delede(int no) {
        DoubleHeroNode t = head;
        if (t.next == null) {
            System.out.println("链表为空");
            return;
        }
        while (true) {
            if (t == null) {
                System.out.println("未找到");
                return;
            }
            if (t.no == no) {
                t.pre.next = t.next;
                //最后一个没有指向后一位的元素
                if (t.next != null) {
                    t.next.pre = t.pre;
                }
            }
            t = t.next;
        }
    }

    /**
     * 找到修改节点,更换数据内容
     *
     * @param newHead 被修改的节点
     */
    public void update(DoubleHeroNode newHead) {
        DoubleHeroNode t = head.next;
        if (head.next == null) {
            System.out.println("链表为空");
        }
        while (true) {
            if (t == null) {
                System.out.println("未找到");
                return;
            }
            if (t.no == newHead.no) {
                t.name = newHead.name;
                t.nikname = newHead.nikname;
                return;
            }
            t = t.next;
        }
    }

    /**
     * 如果本节点的下一个节点时空,就说明本节点时最后一个节点
     *
     * @param newHead 增加的节点
     */
    public void add(DoubleHeroNode newHead) {
        DoubleHeroNode t = head;
        while (true) {
            if (t.next == null) {
                break;
            }
            t = t.next;
        }
        //接到尾部
        t.next = newHead;
        //前指向本节点
        newHead.pre = t;
    }
}

class DoubleHeroNode {
    public int no;
    public String name;
    public String nikname;
    public DoubleHeroNode next;
    public DoubleHeroNode pre;

    @Override
    public String toString() {
        return "DoubleHeroNode{" +
                "no=" + no +
                ", name='" + name + '\'' +
                ", nikname='" + nikname + '\'' +
                '}';
    }

    public DoubleHeroNode(int no, String name, String nikname) {
        this.no = no;
        this.name = name;
        this.nikname = nikname;
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值