双向链表的相关知识

该代码示例展示了如何在Java中实现一个双向链表,包括添加元素、修改元素和删除元素的方法。通过创建一个名为`DoubleLinkedList`的类,并使用辅助节点temp遍历链表,实现了对链表的基本操作。同时,`Person`类作为链表的节点,包含id和name属性以及前后指针。在测试用例中,双向链表被初始化并进行了元素的添加、修改和删除,然后打印了操作后的链表状态。
摘要由CSDN通过智能技术生成

简要:
其实很多东西和单链表是相同的,就是多了一个pre(指向前一个节点的指针)

注意:
三个辅助节点都是 temp = head;

相关图像:
在这里插入图片描述

相关代码:

public class Test {

    public static void main(String[] args){
        DoubleLinkedList d = new DoubleLinkedList();
        Person p1 = new Person (1,"吴中林");
        Person p2 = new Person (2,"吴中");
        Person p3 = new Person (3,"吴帅");
        Person p4 = new Person (1,"胡帅");

        d.add(p1);
        d.add(p2);
        d.add(p3);
        System.out.println("--------加入元素后遍历的结果---------");
        d.list();
        d.update(p4);
        System.out.println("--------修改元素后遍历的结果---------");
        d.list();
        d.delete(1);
        System.out.println("--------删除元素后遍历的结果---------");
        d.list();
    }
}

class DoubleLinkedList{
    Person head = new Person(0,"");


    //加入一个节点到双向链表的最后。
    public void add(Person p){
        Person temp=head;
        //首先找到这条链表的最后的节点。
        while(true){
            if(temp.next==null){
                break;
            }
            else{
                temp = temp.next;
            }
        }
        //找到节点的时候。    形成一个双向链表。
        temp.next = p;
        p.pre = temp;
    }

    //修改双向列表基本上与修改单链表的形式方法是一样的。
    public void update(Person p){
        Person temp=head;//根据id来进行修改p。
        while(true){
            if(temp.next==null){
                break;
            }
            else{
                if(temp.next.id==p.id){
                    temp.next.name=p.name;
                    break;
                }
            }
        }
    }

    public void delete(int id){//根据id来删除节点。
        Person temp=head;
        if(head.next==null){
            System.out.println("当前链表为空,无法删除。");
        }
        boolean flag=false;     //标识是否找到需要删除的节点。
        while(true){
            if(temp==null){
                break;
            }
            else{
                if(temp.id==id){
                    flag = true;
                    break;
                }
                temp=temp.next;
            }
        }
        if(flag){
            temp.pre.next = temp.next;

                temp.next.pre = temp.pre;

            
        }
        else{
            System.out.println("要删除的节点不存在");
        }
    }
    public void list(){
        Person temp=head;
        if(head.next==null){
            System.out.println("链表为空,数据无法列出");
        }
        while(true){
            if(temp.next==null){

                break;
            }
            else {
                System.out.println("id="+temp.next.id+" "+"name="+temp.next.name);
                temp=temp.next;
            }
        }
    }
}

class Person{
    int id;
    String name;
    Person next;    //指向下一个节点。
    Person pre;     //指向前一个节点。

    public Person(int id, String name) {
        this.id = id;
        this.name = name;
    }
}

代码结果:
在这里插入图片描述

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值