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

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 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


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

相关文章
|
2月前
|
存储 算法 Perl
数据结构实验之链表
本实验旨在掌握线性表中元素的前驱、后续概念及链表的建立、插入、删除等算法,并分析时间复杂度,理解链表特点。实验内容包括循环链表应用(约瑟夫回环问题)、删除单链表中重复节点及双向循环链表的设计与实现。通过编程实践,加深对链表数据结构的理解和应用能力。
65 4
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
101 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
9天前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
2月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
70 5
|
2月前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
116 4
|
2月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
2月前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
2月前
|
算法
数据结构之购物车系统(链表和栈)
本文介绍了基于链表和栈的购物车系统的设计与实现。该系统通过命令行界面提供商品管理、购物车查看、结算等功能,支持用户便捷地管理购物清单。核心代码定义了商品、购物车商品节点和购物车的数据结构,并实现了添加、删除商品、查看购物车内容及结算等操作。算法分析显示,系统在处理小规模购物车时表现良好,但在大规模购物车操作下可能存在性能瓶颈。
53 0
|
3月前
|
存储 Java
数据结构第三篇【链表的相关知识点一及在线OJ习题】
数据结构第三篇【链表的相关知识点一及在线OJ习题】
34 7
|
3月前
|
存储 Java
数据结构第二篇【关于java线性表(顺序表)的基本操作】
数据结构第二篇【关于java线性表(顺序表)的基本操作】
49 6

热门文章

最新文章