Java 提供了丰富的数据结构来处理和组织数据【1】

Java 的 java.util 包中提供了许多这些数据结构的实现,可以根据需要选择合适的类。

以下是一些常见的 Java 数据结构:

数组(Arrays)

数组(Arrays)是一种基本的数据结构,可以存储固定大小的相同类型的元素。

int[] array = new int[5];
  • 特点:固定大小,存储相同类型的元素。
  • 优点:随机访问元素效率高。
  • 缺点:大小固定,插入和删除元素相对较慢。

列表(Lists)

Java 提供了多种列表实现,如 ArrayList 和 LinkedList。

List<String> arrayList = new ArrayList<>(); List<Integer> linkedList = new LinkedList<>();

ArrayList:

  • 特点:动态数组,可变大小。
  • 优点:高效的随机访问和快速尾部插入。
  • 缺点:中间插入和删除相对较慢。

LinkedList:

  • 特点:双向链表,元素之间通过指针连接。
  • 优点:插入和删除元素高效,迭代器性能好。
  • 缺点:随机访问相对较慢。

集合(Sets)

集合(Sets)用于存储不重复的元素,常见的实现有 HashSet 和 TreeSet。

Set<String> hashSet = new HashSet<>(); Set<Integer> treeSet = new TreeSet<>();

HashSet:

  • 特点:无序集合,基于HashMap实现。
  • 优点:高效的查找和插入操作。
  • 缺点:不保证顺序。

TreeSet:

  • 特点:TreeSet 是有序集合,底层基于红黑树实现,不允许重复元素。
  • 优点:提供自动排序功能,适用于需要按顺序存储元素的场景。
  • 缺点:性能相对较差,不允许插入 null 元素。

映射(Maps)

映射(Maps)用于存储键值对,常见的实现有 HashMap 和 TreeMap。

Map<String, Integer> hashMap = new HashMap<>(); Map<String, Integer> treeMap = new TreeMap<>();

HashMap:

  • 特点:基于哈希表实现的键值对存储结构。
  • 优点:高效的查找、插入和删除操作。
  • 缺点:无序,不保证顺序。

TreeMap:

  • 特点:基于红黑树实现的有序键值对存储结构。
  • 优点:有序,支持按照键的顺序遍历。
  • 缺点:插入和删除相对较慢。

栈(Stack)

栈(Stack)是一种线性数据结构,它按照后进先出(Last In, First Out,LIFO)的原则管理元素。在栈中,新元素被添加到栈的顶部,而只能从栈的顶部移除元素。这就意味着最后添加的元素是第一个被移除的。

Stack<Integer> stack = new Stack<>();

Stack 类:

  • 特点:代表一个栈,通常按照后进先出(LIFO)的顺序操作元素。

队列(Queue)

队列(Queue)遵循先进先出(FIFO)原则,常见的实现有 LinkedList 和 PriorityQueue。

Queue<String> queue = new LinkedList<>();

Queue 接口:

  • 特点:代表一个队列,通常按照先进先出(FIFO)的顺序操作元素。
  • 实现类:LinkedList, PriorityQueue, ArrayDeque。

堆(Heap)

堆(Heap)优先队列的基础,可以实现最大堆和最小堆。

PriorityQueue<Integer> minHeap = new PriorityQueue<>(); PriorityQueue<Integer> maxHeap = new PriorityQueue<>(Collections.reverseOrder());

树(Trees)

Java 提供了 TreeNode 类型,可以用于构建二叉树等数据结构。

class TreeNode { int val; TreeNode left; TreeNode right; TreeNode(int x) { val = x; } }

图(Graphs)

图的表示通常需要自定义数据结构或使用图库,Java 没有内建的图类。

以上介绍的只是 Java 中一些常见的数据结构,实际上还有很多其他的数据结构和算法可以根据具体问题选择使用。


其他一些说明

以下这些类是传统遗留的,在 Java2 中引入了一种新的框架-集合框架(Collection),我们后面再讨论。

枚举(Enumeration)

枚举(Enumeration)接口虽然它本身不属于数据结构,但它在其他数据结构的范畴里应用很广。 枚举(The Enumeration)接口定义了一种从数据结构中取回连续元素的方式。

例如,枚举定义了一个叫nextElement 的方法,该方法用来得到一个包含多元素的数据结构的下一个元素。

关于枚举接口的更多信息,请参见枚举(Enumeration)。

位集合(BitSet)

位集合类实现了一组可以单独设置和清除的位或标志。

该类在处理一组布尔值的时候非常有用,你只需要给每个值赋值一"位",然后对位进行适当的设置或清除,就可以对布尔值进行操作了。

关于该类的更多信息,请参见位集合(BitSet)。

向量(Vector)

向量(Vector)类和传统数组非常相似,但是Vector的大小能根据需要动态的变化。

和数组一样,Vector对象的元素也能通过索引访问。

使用Vector类最主要的好处就是在创建对象的时候不必给对象指定大小,它的大小会根据需要动态的变化。

关于该类的更多信息,请参见向量(Vector)

栈(Stack)

栈(Stack)实现了一个后进先出(LIFO)的数据结构。

你可以把栈理解为对象的垂直分布的栈,当你添加一个新元素时,就将新元素放在其他元素的顶部。

当你从栈中取元素的时候,就从栈顶取一个元素。换句话说,最后进栈的元素最先被取出。

关于该类的更多信息,请参见栈(Stack)。

字典(Dictionary)

字典(Dictionary) 类是一个抽象类,它定义了键映射到值的数据结构。

当你想要通过特定的键而不是整数索引来访问数据的时候,这时候应该使用 Dictionary。

由于 Dictionary 类是抽象类,所以它只提供了键映射到值的数据结构,而没有提供特定的实现。

关于该类的更多信息,请参见字典( Dictionary)。

Dictionary 类在较新的 Java 版本中已经被弃用(deprecated),推荐使用 Map 接口及其实现类,如 HashMap、TreeMap 等,来代替 Dictionary。

Map 接口及其实现类 可以参考:Java 集合框架。

哈希表(Hashtable)

Hashtable类提供了一种在用户定义键结构的基础上来组织数据的手段。

例如,在地址列表的哈希表中,你可以根据邮政编码作为键来存储和排序数据,而不是通过人名。

哈希表键的具体含义完全取决于哈希表的使用情景和它包含的数据。

关于该类的更多信息,请参见哈希表(HashTable)。

属性(Properties)

Properties 继承于 Hashtable.Properties 类表示了一个持久的属性集.属性列表中每个键及其对应值都是一个字符串。

Properties 类被许多Java类使用。例如,在获取环境变量时它就作为System.getProperties()方法的返回值。

关于该类的更多信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1156023.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Keil uVision5嵌入式C开发:新手教程(从零配置环境)

从零开始搭建 Keil uVision5 嵌入式开发环境&#xff1a;新手也能看懂的实战指南 你是不是也曾经面对一块 STM32 开发板&#xff0c;手握资料却无从下手&#xff1f;打开 Keil 看着一堆弹窗和选项&#xff0c;心里直打鼓&#xff1a;“这玩意儿到底怎么用&#xff1f;”别急—…

【倒计时一天】2025第八届金猿大数据产业发展论坛——暨AI InfraData Agent趋势论坛丨颁奖典礼·上海

第八届金猿颁奖典礼“重要提示➩ 活动报名&现场签到有好礼&#xff0c;先到先得点此小程序链接可报名参会大数据产业创新服务媒体——聚焦数据 改变商业数智产业正站在变革的临界点上。过去十年&#xff0c;大数据从技术概念演进为基础设施&#xff0c;完成了产业奠基&…

搞定NPU推理加速实战

&#x1f493; 博客主页&#xff1a;借口的CSDN主页 ⏩ 文章专栏&#xff1a;《热点资讯》 NPU推理加速实战&#xff1a;突破边缘智能的效率瓶颈目录NPU推理加速实战&#xff1a;突破边缘智能的效率瓶颈 引言&#xff1a;为什么NPU推理加速是AI落地的生死线 一、现在时&#xf…

了解Java 数据结构【1】

Java 提供了丰富的数据结构来处理和组织数据。 Java 的 java.util 包中提供了许多这些数据结构的实现&#xff0c;可以根据需要选择合适的类。 以下是一些常见的 Java 数据结构&#xff1a; 数组&#xff08;Arrays&#xff09; 数组&#xff08;Arrays&#xff09;是一种基…

Matlab实现图正则化稀疏编码(GraphSC)算法详解

稀疏编码(Sparse Coding)是一种经典的无监督表示学习方法,它通过学习一组过完备基(字典),将输入信号表示为这些基的稀疏线性组合,在图像去噪、特征提取和压缩感知等领域表现出色。然而,传统稀疏编码仅关注单个样本的重构误差,忽略了样本之间的内在几何关系,导致在流形…

智能穿戴OLED显示方案:SSD1306中文手册系统学习

智能穿戴设备的“眼睛”&#xff1a;从零吃透SSD1306 OLED驱动芯片你有没有想过&#xff0c;为什么一块小小的智能手环&#xff0c;能在不换电池的情况下连续显示一周&#xff1f;为什么它的屏幕那么薄、视角那么宽&#xff0c;即使在阳光下也能看清时间&#xff1f;答案&#…

javascript数据类型转换-转换为数字型

第一种转换方式&#xff0c;使用Number语法是Number(数据或者存储数据的变量)let a 12 console.log(Number(a),typeof Number(a))如果是不能转换的类型&#xff0c;返回值是NaN如果内容是空&#xff0c;返回值是0如果转换的是布尔值&#xff0c;true返回1&#xff0c;false返回…

基于实际项目的PCB布局布线思路:初级应用示范

从一块电机驱动板看懂PCB布局的底层逻辑最近带一个新人做项目&#xff0c;他画完第一版直流电机驱动板后兴奋地拿给我看&#xff1a;“功能都连上了&#xff01;”可一上电问题就来了&#xff1a;MCU时不时复位、RS485通信在电机启动时直接中断、编码器计数跳变严重……最后还是…

麒麟V10-ARM架构Docker启动报错

麒麟V10&#xff0c;ARM架构&#xff0c;docker版本20.10.24&#xff0c;docker-compose版本1.17.1&#xff0c;使用docker-compose up -d启动报如下错误Cannot start service : failed to create shim task: OCI runtime create failed: container_linux.go:328: starting con…

项目应用中c++ spidev0.0 read值为255的解决方案

当/dev/spidev0.0读出全是255&#xff1f;一文搞懂SPI通信中的“假高电平”陷阱在做嵌入式Linux项目时&#xff0c;你有没有遇到过这种情况&#xff1a;明明代码写得清清楚楚&#xff0c;打开/dev/spidev0.0、调用read()函数去拿传感器数据&#xff0c;结果返回的每一个字节都是…

批量 roi 目录 roi

roi_dir.pyimport globimport cv2 import numpy as np import json import osclass ROIDrawer:def __init__(self, image_o, label"tiaosheng"):self.drawing Falseself.ix, self.iy -1, -1self.rois [] # 存储多个ROIself.image_o image_oself.image self.ima…

三种神经网络BP-PID、RBF-PID、单神经元自适应优化PID算法对比仿真(程序+参考资料)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

零基础入门:理解AUTOSAR中DIO驱动配置

零基础也能懂&#xff1a;AUTOSAR中DIO驱动配置的“人话”指南你有没有遇到过这样的情况&#xff1f;换了个MCU芯片&#xff0c;原本好好的LED控制代码突然不亮了——不是灯坏了&#xff0c;而是GPIO引脚变了。于是你只能翻数据手册、查寄存器、改代码……一通操作下来&#xf…

LVGL移植实战案例:配合DMA2D加速GUI绘制

让LVGL在STM32上“飞”起来&#xff1a;DMA2D加速GUI绘制实战详解你有没有遇到过这样的场景&#xff1f;辛辛苦苦用LVGL搭好了界面&#xff0c;按钮、滑动条、图表一应俱全&#xff0c;结果一滑动就卡顿&#xff0c;动画像幻灯片一样一帧一卡。打开调试器一看&#xff0c;CPU占…

Cortex-M浮点单元(FPU)使用指南:新手必看示例

掌握Cortex-M的浮点加速引擎&#xff1a;FPU实战全解析你有没有遇到过这种情况&#xff1f;在STM32上跑一个FFT&#xff0c;采样率刚到48kHz&#xff0c;处理器就满负荷运转&#xff1b;或者写了个PID控制器&#xff0c;参数一调精&#xff0c;系统就开始抖动——不是算法有问题…

模糊PID与PID控制simulink仿真比较(Simulink仿真实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

ST7789V硬件时序详解:系统学习初始化流程

深入ST7789V&#xff1a;从硬件时序到初始化流程的系统性解析在嵌入式显示开发中&#xff0c;点亮一块屏幕看似简单——接上电源、写几条命令、刷点颜色。但当你真正动手时&#xff0c;却常常遇到花屏、黑屏、白屏、颜色错乱等问题。这些问题的背后&#xff0c;往往不是代码写错…

Proteus8.9下载安装教程:小白指南(含资源获取渠道)

从零开始安装 Proteus 8.9&#xff1a;工程师亲测的实战避坑指南你是不是也曾在深夜对着“License Not Found”弹窗抓耳挠腮&#xff1f;是不是下载了十几个G的安装包&#xff0c;点开却提示“缺少 VDM 引擎”&#xff1f;又或者&#xff0c;好不容易装上了&#xff0c;仿真时单…

Keil芯片包管理详解:如何为STM32选择正确版本

Keil芯片包管理实战&#xff1a;如何为STM32选对版本&#xff0c;避开90%工程师踩过的坑你有没有遇到过这样的场景&#xff1f;刚从CubeMX导出一个Keil工程&#xff0c;编译时却报错&#xff1a;“TIM8未定义”&#xff1f;或者调试时发现寄存器窗口一片空白&#xff0c;SVD视图…

基于STM32的多点温度采集系统构建

打造工业级多点温度监控系统&#xff1a;STM32实战全解析你有没有遇到过这样的场景&#xff1f;一台设备里几十个关键部件在发热&#xff0c;却只能靠一个温度探头“猜”整体状态&#xff1b;或者冷链运输途中&#xff0c;货品因局部高温变质&#xff0c;而监测系统毫无察觉。问…