数据结构(Java实现)LinkedList与链表(下)

这篇具有很好参考价值的文章主要介绍了数据结构(Java实现)LinkedList与链表(下)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
**数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
**
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
结论
让一个指针从链表起始位置开始遍历链表,同时让一个指针从判环时相遇点的位置开始绕环运行,两个指针都是每次均走一步,最终肯定会在入口点的位置相遇。

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


LinkedList的模拟实现
单个节点的实现
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


尾插
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
运行结果如下:
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表

数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
也可以暴力使用
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


全部代码
MyLinkedList

public class MyLinkedList {
    static class ListNode{
        public  int val;
        public ListNode prev;
        public ListNode next;

        public ListNode(int val) {
            this.val = val;
        }
    }
    public  ListNode head;
    public  ListNode last;

    //链表的长度
    public int size(){
        int len=0;
        ListNode cur=head;
        while(cur!=null){
            cur=cur.next;
            len++;
        }
        return len;
    }

    //打印链表
    public  void dispaly(){
        ListNode cur=head;
        while(cur!=null){
            System.out.print(cur.val+" ");
            cur=cur.next;
        }
        System.out.println();
    }

    //查找关键字key是否在链表中
    public boolean contains(int key){
        ListNode cur=head;
        while(cur!=null){
            if(cur.val==key){
                return true;
            }
            cur=cur.next;
        }
        return false;
    }

    //头插
public void addFirst(int data){
    ListNode node=new ListNode(data);
    //空链表
    if(head==null){
        head=node;
        last=node;
        return;
    }
    //一般情况
    node.next=head;
    head.prev=node;
    head=node;
    }

    //尾插
    public void addLast(int data){
        ListNode node=new ListNode(data);
        //空链表
        if(head==null){
            head=node;
            last=node;
            return;
        }
        //一般情况
        last.next=node;
        node.prev=last;
        last=node;
    }
//无论是头插还是尾插,只要是空链表,那么新增节点的next和prev都引用自身

    //任意位置的插入,在位置后面插入
    public void AddIndex(int index,int data){
        ListNode node=new ListNode(data);

        if(index<0||index>size()){
            throw new IndexOutOfBounds("任意位置插入,坐标非法,非法值为"+index);
        }
        if(index==0){
            addFirst(data);
            return;
        }
        if(index==size()){
            addLast(data);
            return;
        }

        //一般情况
        ListNode cur=head;
        while(index!=0){
            cur=cur.next;
            index--;
        }
        node.next=cur;
        cur.prev.next=node;
        node.prev=cur.prev;
        cur.prev=node;

    }

//删除第一次出现关键字为key的节点
    public void remove(int key){

        //链表为空
        if(head==null){
            return;
        }
        //只有一个节点并且该节点值为key
        if(head.next==null&&head.val==key){
            head.prev=null;
            head.next=null;
            return;
        }
        //头节点
        if(head.val==key)
        {
            head.next.prev=null;
            head=head.next;
            return;
        }
        //尾节点
        if(last.val==key){
            last.prev.next=null;
            last=last.prev;
            return;
        }
        //一般情况
        ListNode cur=head;
        while(cur!=null){
            if(cur.val==key){
                cur.prev.next=cur.next;
                cur.next.prev=cur.prev;
                return;
            }
            cur=cur.next;
        }
    }

    //删除所有出现关键字为key的节点
    public void removeAll(int key){

        //链表为空
        if(head==null){
            return;
        }
        //只有一个节点并且该节点值为key
        if(head.next==null&&head.val==key){
            head.prev=null;
            head.next=null;
            return;
        }
        //头节点
        if(head.val==key)
        {
            head.next.prev=null;
            head=head.next;

        }
        //尾节点
        if(last.val==key){
            last.prev.next=null;
            last=last.prev;

        }
        //一般情况
        ListNode cur=head;
        while(cur!=null){
            if(cur.val==key){
                cur.prev.next=cur.next;
                cur.next.prev=cur.prev;
            }
            cur=cur.next;
        }
    }


    //clear
    public  void clear(){
/*        ListNode cur=head;
        while(cur!=null){
            ListNode curNext=cur.next;//存储下一个节点,方便下次循环使用
            cur.prev=null;
            cur.next=null;
            cur=curNext;//更新当前节点
        }*/
        head=null;
        last=null;//使头节点和尾节点的地址置空
    }

}

IndexOutOfBounds

public class IndexOutOfBounds extends  RuntimeException{
    public IndexOutOfBounds() {
    }

    public IndexOutOfBounds(String message) {
        super(message);
    }
}

Test1

public class Test1 {
    public static void main(String[] args) {
        MyLinkedList myLinkedList=new MyLinkedList();
        myLinkedList.addFirst(34);
        myLinkedList.addFirst(3);
        myLinkedList.addFirst(4);
        myLinkedList.addFirst(340);
        myLinkedList.addFirst(344);
        myLinkedList.dispaly();
        System.out.println(myLinkedList.size());
        System.out.println(myLinkedList.contains(4));
        System.out.println("我是分割线");
        myLinkedList.addLast(-12);
        myLinkedList.addLast(-121);
        myLinkedList.addLast(-1222);
        myLinkedList.dispaly();
        myLinkedList.AddIndex(3,999);
        myLinkedList.dispaly();
       // myLinkedList.AddIndex(55,999);
        System.out.println("我是分割线");
        myLinkedList.remove(999);
        myLinkedList.dispaly();
        myLinkedList.remove(344);
        myLinkedList.dispaly();
        myLinkedList.addFirst(-12);
        myLinkedList.addLast(-12);
        myLinkedList.dispaly();
        myLinkedList.removeAll(-12);
        myLinkedList.dispaly();
        System.out.println("我是分割线");
        myLinkedList.clear();
        myLinkedList.dispaly();
        System.out.println("证明有空行");


    }
}

什么是LinkedList
LinkedList的底层是双向链表结构(链表后面介绍),由于链表没有将元素存储在连续的空间中,元素存储在单独的节点中,然后通过引用将节点连接起来了,因此在在任意位置插入或者删除元素时,不需要搬移元素,效率比较高。


LinkedList的使用
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


LinkedList的其他常用方法
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


LinkedList的遍历
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表


ArrayList和LinkedList的区别
数据结构(Java实现)LinkedList与链表(下),数据结构(Java实现),数据结构,java,链表文章来源地址https://www.toymoban.com/news/detail-674770.html


到了这里,关于数据结构(Java实现)LinkedList与链表(下)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构 | 入门】线性表与链表 (问题引入&实现&算法优化)

    🤵‍♂️ 个人主页: @计算机魔术师 👨‍💻 作者简介:CSDN内容合伙人,全栈领域优质创作者。 本文是浙大数据结构学习笔记专栏 这里我们引入一个问题,最常见的多项式,我们如何使用编程将多项式表示出来呢? 我们可以使用数组来表示,但是会随着一个问题,如下图底

    2024年01月21日
    浏览(71)
  • [Collection与数据结构] 链表与LinkedList (一):链表概述与单向无头非循环链表实现

    上篇文章我们已经对顺序表进行了实现,并且对ArrayList进行了使用,我们知道ArrayList底层是使用数组实现的. 由于其底层是一段连续空间,当在ArrayList任意位置插入或者删除元素时, 就需要将后序元素整体往前或者往后搬移,时间复杂度为O(n),效率比较低 ,因此ArrayList不适合做

    2024年04月26日
    浏览(64)
  • 《数据结构与算法》之队列与链表复习

    我们在上一次学习了堆栈的数据结构以后,可以了解到它是受限制的操作,比如我们操作只能在栈顶,现在我们要学习的东西叫做队列,它也是受限制的一种数据结构,它的特点是队头只出数据,而队尾只入数据, 它的结构就和它的名字,像我们平时排队一样先来的人肯定要

    2024年02月08日
    浏览(66)
  • 【数据结构】链表与LinkedList

    作者主页: paper jie 的博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于《JAVA数据结构》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将javaSE基础知识一网打尽,希望可以帮到读者们哦。 其他专栏

    2024年02月08日
    浏览(49)
  • LinkedList数据结构链表

    LinkedList 在Java中是一个实现了 List 和 Deque 接口的双向链表。它允许我们在列表的两端添加或删除元素,同时也支持在列表中间插入或移除元素。在分析 LinkedList 之前,需要理解链表这种数据结构: 链表 :链表是一种动态数据结构,由一系列节点组成,每个节点包含数据部分

    2024年02月20日
    浏览(44)
  • 【数据结构(三)】链表与LinkedList

    ❣博主主页: 33的博客❣ ▶️文章专栏分类:数据结构◀️ 🚚我的代码仓库: 33的代码仓库🚚 🫵🫵🫵 关注我带你学更多数据结构知识 在上一篇文章中,我们已经认识了顺序表,通过源码我们知道ArrayList底层是使用数组来存储元素,当在ArrayList任意位置插入或者删除元素时,

    2024年04月13日
    浏览(52)
  • 【数据结构二】链表和LinkedList详解

    目录 链表和LinkedList  1.链表的实现 2.LinkedList的使用 3.ArrayList和LinkedList的区别 4.链表OJ题训练         当 在 ArrayList 任意位置插入或者删除元素时,就需要将后序元素整体往前或者往后 搬移,时间复杂度为 O(n) ,效率比较低,因此 ArrayList 不适合做任意位置插入和删除比较多

    2024年01月20日
    浏览(45)
  • 从0开始学C++ 第二十七课 数据结构入门 - 数组与链表

    第二十七课:数据结构入门 - 数组与链表 学习目标: 理解数组的基本概念和操作。 掌握链表的基本结构与特点。 学会在C++中定义和操作数组和链表。 了解数组和链表的基本使用场景。 学习内容: 数组(Array) 概念:数组是一种线性数据结构,用一段连续的内存空间来存储

    2024年01月23日
    浏览(50)
  • 【数据结构与算法】之8道顺序表与链表典型编程题心决!

                                                                                    个人主页:秋风起,再归来~                                                                                             数据结构与算

    2024年04月14日
    浏览(58)
  • 【数据结构与算法】顺序表与链表(单链表和双链表)超详解图示与源码。

                                                       大家好,今天我们来学习数据结构中的顺序表与链表!源码在最后附上 首先我们先来认识一下 顺序表 :                                       **如上图所示:很多人会以为数组就是顺序表,顺序表就是数组,这

    2024年02月21日
    浏览(59)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包