Java数据结构——————双向链表(详细图解,增删改查详细实现)(下)

简介: Java数据结构——————双向链表(详细图解,增删改查详细实现)(下)

2.获取第一个元素和最后一个元素

//获取第一个元素
    public T getFirst() {
        //需要判断链表是否为空
        if (isEmpty()) {
            return null;
        }
        return head.next.item;
    }
    //获取最后一个元素
    public T getLast() {
        if (isEmpty()) {
            return null;
        }
        return last.item;
    }

解析:无论是获取哪个,我们都需要获取判空操作,养成好习惯,代码一定要考虑进所有情况,否则容易出异常。因为是获取元素,所以我们返回的一定是某个结点的item,第一个元素,说明就是头结点的next的item,最后一个元素就是返回last的item就好。


3.添加元素t


//插入元素t
        public void add(T t) {
            //如果链表为空
            if (isEmpty()) {
                //创建新结点
                Node newNode = new Node(t, head, null);
                //让新节点为尾结点
                last = newNode;
                //让头结点指向尾结点
                head.next = last;
            } else {
                //如果链表不为空
                Node oldLast = last;
                //创建新节点
                Node newNode = new Node(t, oldLast, null);
                //让当前的尾结点指向新结点
                oldLast.next = newNode;
                //让新节点成为尾结点
                last = newNode;
            }
            N++;
        }

解析:同样我们需要对链表进行判空操作,如果链表为空,我们需要new一个新节点存入数据t,因为就它一个结点,所以我们把它赋值给last,让它成为尾结点,然后让head指向它即可。如果链表不为空,我们首先需要用一个结点oldLast记录旧的尾结点,同时new一个新节点放入数据t,让它成为新的尾结点last,同时让旧的尾结点oldLast指向它。最后无论怎样都记得让N++。


4.向指定位置i插入元素t


//向指定位置i位置插入元素t
    public void insert(int i,T t){
        //找到i位置的前一个节点
        Node a=head;
        for (int j = 0; j < i; j++) {
            a=a.next;
        }
        //找到i位置的节点
        Node curr = a.next;
        //创建新节点
        Node newNode = new Node(t, a, curr);
        //让i位置的前一个节点的下一个节点变为新节点
        a.next=newNode;
        //让i位置的前一个节点变为新节点
        curr.pre=newNode;
        //元素个数加1
        N++;
    }

具体的步骤通过下图就能明白,一定要搞清楚每一步的顺序,否则很容易出错,自己可以草稿画图模拟。


image.png


5.获取指定位置i处的元素


//获取指定位置i处的元素
    public T get(int i){
        Node a=head;
        for (int j = 0; j <=i; j++) {
            a=a.next;
        }
        return a.item;
    }

解析:和单链表相同,从头结点开始遍历打i处,返回item即可。


6.找到元素t第一次出现的位置


//找到元素t第一次出现的位置
    public int indexOf(T t){
        Node a=head;
        for (int i = 0; i < N; i++) {
            a=a.next;
            if(a.item==t) return i;
        }
        return -1;
    }

解析:单单链表一致,从头结点开始遍历,同时判断是否是查找的元素,如果找到返回位置i,否则循环结束后返回-1。


7.删除位置i的元素,并返回该元素


//删除位置i处的元素,并返回该元素
    public T remove(int i){
        Node a=head;
        //找到i节点
        for (int j = 0; j <= i; j++) {
            a=a.next;
        }
        a.next.pre=a.pre;
        a.pre.next=a.next;
        N--;
        return a.item;
    }

如下图解即可明白,主要是要分清步骤,不要搞混,返回的是值不是结点。


image.png


总结:双向链表与单链表虽然有所区别,但方法的实现大同小异,我们也应该熟练掌握,多画图更易帮助我们理解,都是基础的知识。

相关文章
|
6月前
|
前端开发 Java
java实现队列数据结构代码详解
本文详细解析了Java中队列数据结构的实现,包括队列的基本概念、应用场景及代码实现。队列是一种遵循“先进先出”原则的线性结构,支持在队尾插入和队头删除操作。文章介绍了顺序队列与链式队列,并重点分析了循环队列的实现方式以解决溢出问题。通过具体代码示例(如`enqueue`入队和`dequeue`出队),展示了队列的操作逻辑,帮助读者深入理解其工作机制。
167 1
|
4月前
|
存储 安全 Java
Java 集合面试题从数据结构到 HashMap 源码剖析详解及长尾考点梳理
本文深入解析Java集合框架,涵盖基础概念、常见集合类型及HashMap的底层数据结构与源码实现。从Collection、Map到Iterator接口,逐一剖析其特性与应用场景。重点解读HashMap在JDK1.7与1.8中的数据结构演变,包括数组+链表+红黑树优化,以及put方法和扩容机制的实现细节。结合订单管理与用户权限管理等实际案例,展示集合框架的应用价值,助你全面掌握相关知识,轻松应对面试与开发需求。
198 3
|
12月前
|
存储 Java
Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。
【10月更文挑战第19天】本文详细介绍了Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。HashMap以其高效的插入、查找和删除操作著称,而TreeMap则擅长于保持元素的自然排序或自定义排序,两者各具优势,适用于不同的开发场景。
122 1
|
12月前
|
存储 Java
告别混乱!用Java Map优雅管理你的数据结构
【10月更文挑战第17天】在软件开发中,随着项目复杂度增加,数据结构的组织和管理至关重要。Java中的Map接口提供了一种优雅的解决方案,帮助我们高效、清晰地管理数据。本文通过在线购物平台的案例,展示了Map在商品管理、用户管理和订单管理中的具体应用,有效提升了代码质量和维护性。
205 2
|
6月前
|
存储 Java 编译器
Java 中 .length 的使用方法:深入理解 Java 数据结构中的长度获取机制
本文深入解析了 Java 中 `.length` 的使用方法及其在不同数据结构中的应用。对于数组,通过 `.length` 属性获取元素数量;字符串则使用 `.length()` 方法计算字符数;集合类如 `ArrayList` 采用 `.size()` 方法统计元素个数。此外,基本数据类型和包装类不支持长度属性。掌握这些区别,有助于开发者避免常见错误,提升代码质量。
478 1
|
10月前
|
存储 缓存 安全
Java 集合江湖:底层数据结构的大揭秘!
小米是一位热爱技术分享的程序员,本文详细解析了Java面试中常见的List、Set、Map的区别。不仅介绍了它们的基本特性和实现类,还深入探讨了各自的使用场景和面试技巧,帮助读者更好地理解和应对相关问题。
146 5
|
11月前
|
缓存 算法 Java
本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制
在现代软件开发中,性能优化至关重要。本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制。通过调整垃圾回收器参数、优化堆大小与布局、使用对象池和缓存技术,开发者可显著提升应用性能和稳定性。
173 6
|
11月前
|
存储 Java 索引
Java中的数据结构:ArrayList和LinkedList的比较
【10月更文挑战第28天】在Java编程世界中,数据结构是构建复杂程序的基石。本文将深入探讨两种常用的数据结构:ArrayList和LinkedList,通过直观的比喻和实例分析,揭示它们各自的优势与局限,帮助你在面对不同的编程挑战时做出明智的选择。
|
12月前
|
存储 算法 Java
Java 中常用的数据结构
【10月更文挑战第20天】这些数据结构在 Java 编程中都有着广泛的应用,掌握它们的特点和用法对于提高编程能力和解决实际问题非常重要。
246 6
|
12月前
|
存储 Java 开发者
Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效
【10月更文挑战第19天】在软件开发中,随着项目复杂度的增加,数据结构的组织和管理变得至关重要。Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效。本文通过在线购物平台的案例,展示了Map在商品管理、用户管理和订单管理中的具体应用,帮助开发者告别混乱,提升代码质量。
114 1