Java集合核心内容之数组和链表,大厂越来越注重基础了,建议收藏

举报
波波烤鸭 发表于 2022/03/31 00:54:43 2022/03/31
【摘要】   现在出去找工作,如果你不能很好的和面试官去聊聊Java基础里面的算法和用到的数据结构,基本是没戏的,所以本篇开始我们会给大家详细的聊聊Java集合中的相关实现涉及到的数据结构和算法实现,本文先来介绍下...

  现在出去找工作,如果你不能很好的和面试官去聊聊Java基础里面的算法和用到的数据结构,基本是没戏的,所以本篇开始我们会给大家详细的聊聊Java集合中的相关实现涉及到的数据结构和算法实现,本文先来介绍下最最简单的数据结构,数组和链表。
在这里插入图片描述
在这里插入图片描述

一、数组

  数组是我们使用到的最简单的一个数据结构,数组的使用

// 动态初始化:初始化时由程序员只指定数组长度,由系统为数组元素分配初始值
char c1[] = new char[5];
// 静态初始化: 初始化时由程序员显示置顶每个数组的初始值,由系统决定数组长度
char c2[] = new char[]{'E','D','U','Y','U'};
char c3[] = {'E','D','U','Y','U'};

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

  具有如下的特点:

  • 内存地址连续,
  • 可以通过下标的成员访问,下标访问的性能高
  • 增删操作带来更大的性能消耗(保证数据越界的问题,需动态扩容)

在这里插入图片描述

二、链表

  链表也是线性的顺序存储数据。只是在内存地址上不是连续的,每一个节点里存到下一个节点的指针(Pointer)

1 单向链表

  单向链表(单链表)是链表的一种,它由节点组成,每个节点都包含下一个节点的指针,下图就是一个单链表,表头为空,表头的后继节点是"结点10"(数据为10的结点),“节点10"的后继结点是"节点20”(数据为10的结点)
在这里插入图片描述
  然后我们来看下删除链表的操作,比如删除30这个节点
在这里插入图片描述  在上面的结构基础上我们再来添加一个节点到链表中
在这里插入图片描述

2 双向链表

  双向链表(双链表)是链表的一种。和单链表一样,双链表也是由节点组成,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。

  双链表的示意图如下:

在这里插入图片描述
  双向链表的具体实现可以参考

    static final class Node {
       // 前一个节点
        volatile Node prev;

        // 后一个节点
        volatile Node next;

		// 链表节点存储的具体数据
        volatile Thread thread;


    }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

  我们看看双向链表删除节点的操作,比如说下面这个单链表中我们要删除"节点30"。

删除之前:“节点20"的后继节点为"节点30”,“节点30” 的前继节点为"节点20"。“节点30"的后继节点为"节点40”,“节点40” 的前继节点为"节点30"。

删除之后:“节点20"的后继节点为"节点40”,“节点40” 的前继节点为"节点20"。
在这里插入图片描述

  我们再来看看双向链表添加节点的操作,比如说下面这个双向链表在"节点10"与"节点20"之间添加"节点15"

添加之前:“节点10"的后继节点为"节点20”,“节点20” 的前继节点为"节点10"。

添加之后:“节点10"的后继节点为"节点15”,“节点15” 的前继节点为"节点10"。“节点15"的后继节点为"节点20”,“节点20” 的前继节点为"节点15"。
在这里插入图片描述

~数据和链表的内容相对来说比较简单,我们就给大家介绍到这里了。 欢迎点赞关注加收藏哦V_V

文章来源: dpb-bobokaoya-sm.blog.csdn.net,作者:波波烤鸭,版权归原作者所有,如需转载,请联系作者。

原文链接:dpb-bobokaoya-sm.blog.csdn.net/article/details/117913673

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。