Java 中常见的数据结构算法及其应用

Java 中常见的数据结构算法及其应用

在Java编程中,选择合适的数据结构对程序的性能和可维护性至关重要。本文将详细介绍Java中常见的数据结构及其应用场景,包括数组、链表、栈、队列、双端队列、集合、映射、堆、树、图和列表。

1. 数组 (Array)

数组是一种基础的数据结构,用于存储固定大小的相同类型元素的集合。它使用连续的内存空间存储,因此可以通过索引快速访问元素。数组的主要缺点是大小固定,且插入和删除操作效率较低。

定义和初始化数组:

// 方法一:指定数组类型和大小,元素会自动初始化为其默认值(整数为0)
int[] numbers = new int[5];// 方法二:使用数组字面量直接初始化数组
int[] numbers = {1, 2, 3, 4, 5};

应用场景:

  • 需要快速访问元素的场景,例如实现栈和队列。
  • 固定大小的集合,例如保存一周的温度记录。

学习更多请参考:Java 数组详解:定义、操作与应用

2. 链表 (Linked List)

链表由节点组成,每个节点包含数据和一个指向下一个节点的引用。链表可以是单链表(单向)或双链表(双向)。相比数组,链表在插入和删除操作上更为高效,但访问速度较慢。

定义单链表节点类:

class ListNode {int val;ListNode next;ListNode(int x) { val = x; }
}

应用场景:

  • 动态大小的集合,频繁的插入和删除操作。
  • 实现复杂数据结构,如栈、队列和图。

3. 栈 (Stack)

栈是一种LIFO(后进先出)的数据结构,只能在一端(栈顶)进行插入和删除操作。Java中可以使用 Stack 类或 Deque 接口实现栈。

使用Stack类:

Stack<Integer> stack = new Stack<>();
stack.push(1);
stack.push(2);
System.out.println(stack.pop()); // 输出:2
System.out.println(stack.peek()); // 输出:1

应用场景:

  • 表达式求值(例如中缀表达式转后缀表达式)。
  • 回溯算法(如深度优先搜索)。

4. 队列 (Queue)

队列是一种FIFO(先进先出)的数据结构,元素在一端(队尾)添加,在另一端(队头)删除。Java中可以使用 Queue 接口及其实现类,如 LinkedList

使用LinkedList实现队列:

Queue<Integer> queue = new LinkedList<>();
queue.offer(1);
queue.offer(2);
System.out.println(queue.poll()); // 输出:1
System.out.println(queue.peek()); // 输出:2

应用场景:

  • 任务调度和处理。
  • 宽度优先搜索(BFS)算法。

5. 双端队列 (Deque)

双端队列支持在两端进行插入和删除操作。Java中可以使用 Deque 接口及其实现类,如 ArrayDeque 和 LinkedList。

使用ArrayDeque实现双端队列:

Deque<Integer> deque = new ArrayDeque<>();
deque.addFirst(1);
deque.addLast(2);
System.out.println(deque.removeFirst()); // 输出:1
System.out.println(deque.removeLast()); // 输出:2

应用场景:

  • 双向队列,如浏览器的前进和后退功能。
  • 实现复杂数据结构,如最大/最小队列。

6. 集合 (Set)

集合是一种不允许重复元素的集合。Java中常见的实现有 HashSet、LinkedHashSet 和 TreeSet。

使用HashSet:

Set<Integer> set = new HashSet<>();
set.add(1);
set.add(2);
set.add(1); // 不会添加重复元素
System.out.println(set); // 输出:[1, 2]

应用场景:

  • 去重操作,例如从列表中删除重复元素。
  • 集合运算,如求交集、并集和差集。

7. 映射 (Map)

映射是一种键值对的集合,每个键最多对应一个值。Java中常见的实现有 HashMap、LinkedHashMap 和 TreeMap。

使用HashMap:

Map<String, Integer> map = new HashMap<>();
map.put("one", 1);
map.put("two", 2);
System.out.println(map.get("one")); // 输出:1
System.out.println(map.containsKey("three")); // 输出:false

应用场景:

  • 快速查找和更新键值对。
  • 缓存实现,如LRU缓存(更多请参考:LRU(Least Recently Used)算法原理)。

更多请参考:深入解析Java HashMap的高性能扩容机制与树化优化

8. 堆 (Heap)

堆是一种特殊的完全二叉树,通常用于实现优先队列。Java中可以使用 PriorityQueue 类。

使用PriorityQueue:

PriorityQueue<Integer> heap = new PriorityQueue<>();
heap.offer(3);
heap.offer(1);
heap.offer(2);
System.out.println(heap.poll()); // 输出:1
System.out.println(heap.peek()); // 输出:2

应用场景:

  • 优先级调度,例如任务调度和路径查找。
  • 求中位数和Top K问题。

9. 树 (Tree)

树是一种分层数据结构,由节点和边组成。二叉树是最常见的树结构,Java中常用 TreeSet 和 TreeMap。

定义二叉树节点类:

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

应用场景:

  • 分层数据表示,例如文件系统。
  • 搜索和排序操作,如二叉搜索树(BST)。

10. 图 (Graph)

图是一种非线性数据结构,由顶点和边组成。可以表示各种关系,如社交网络和交通网络。

定义图的邻接表表示:

class Graph {private Map<Integer, List<Integer>> adjList = new HashMap<>();public void addEdge(int v, int w) {adjList.computeIfAbsent(v, k -> new LinkedList<>()).add(w);adjList.computeIfAbsent(w, k -> new LinkedList<>()).add(v);}
}

应用场景:

  • 路径查找算法,如Dijkstra算法。
  • 关系表示和分析,如社交网络分析。

11. 哈希表 (Hash Table)

哈希表使用哈希函数将键映射到值,支持快速插入、删除和查找操作。Java中 HashMap 是常见的实现。

使用HashMap:

Map<String, Integer> hashTable = new HashMap<>();
hashTable.put("apple", 1);
hashTable.put("banana", 2);
System.out.println(hashTable.get("apple")); // 输出:1
System.out.println(hashTable.containsKey("banana")); // 输出:true

应用场景:

  • 高效的查找和更新操作。
  • 数据去重和索引。

12. 列表 (List)

列表是一种有序的集合,允许重复元素。Java中常见的实现有 ArrayList 和 LinkedList。

使用ArrayList:

ArrayList 是基于动态数组实现的,支持随机访问,插入和删除操作在最坏情况下是O(n),但在末尾插入操作是O(1)。

List<Integer> arrayList = new ArrayList<>();
arrayList.add(1);
arrayList.add(2);
arrayList.add(3);
System.out.println(arrayList.get(0)); // 输出:1
System.out.println(arrayList.get(1)); // 输出:2
System.out.println(arrayList.get(2)); // 输出:3// 遍历 ArrayList
for (int num : arrayList) {System.out.println(num);
}

使用LinkedList:

LinkedList 是基于双向链表实现的,适合频繁的插入和删除操作,但随机访问性能较差。

List<Integer> linkedList = new LinkedList<>();
linkedList.add(1);
linkedList.add(2);
linkedList.add(3);
System.out.println(linkedList.get(0)); // 输出:1
System.out.println(linkedList.get(1)); // 输出:2
System.out.println(linkedList.get(2)); // 输出:3// 遍历 LinkedList
for (int num : linkedList) {System.out.println(num);
}

应用场景:

  • 动态数组,适合频繁的插入和删除操作(ArrayList)。
  • 双向链表,适合在任意位置进行插入和删除操作(LinkedList)。

这些数据结构在Java中的实现和应用场景各不相同,选择合适的数据结构可以显著提升程序的性能和可维护性。理解并掌握这些数据结构的特性和使用场景,将有助于编写高效、可靠的Java程序。

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

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

相关文章

React的Redux的状态管理

步骤 1.创建新项目 npx create-react-app react-redux 2.安装配套工具 npm i reduxjs/toolkit react-redux 3.启动项目 npm run start 4.在src目录下创建store文件夹 5.在store文件夹下创建modules文件夹 6.在store文件夹里创建index.js文件 7.在counterStore.js文件…

Python入门-基础知识-模块

Python程序中的模块的功能与函数相似&#xff0c;有助于更好地组织代码&#xff0c;提高代码的利用率。模块是一 种以“.py”为扩展名的文件&#xff0c;其中可以包含变量、函数等各种代码形式。导入模块后&#xff0c;就可以使用 模块中的变量、函数等。Python库着重强调功能性…

随着量子计算的崭露头角,C 语言在未来是否需要做出适应性的改变,以适应新的计算架构和算法?

随着量子计算的发展&#xff0c;C语言可能需要进行一些适应性的改变以适应新的计算架构和算法。量子计算与经典计算存在很大的差异&#xff0c;涉及到量子比特、量子门和量子算法等概念。因此&#xff0c;为了更好地支持量子计算&#xff0c;C语言可能需要引入新的数据类型和算…

JS面试题7——localStorage,sessionStorage,cookie的区别

公共点&#xff1a;都是用于在客户端存放数据的 区别&#xff1a; 1. 数据存放的有效期不同 <script> sessionStorage.setItem("key", "123"); // 仅在当前浏览器窗口关闭前有效 localStorage.setItem("key", "456"); // 持久化…

自动化代码规范检查--Sonarqube部署

参考文档 官方文档安装数据库 官方给出几种数据库: # 我们选用postgres, 拉取镜像 docker pull postgres:16.0# 创建存储卷 docker volume create postgresql-data# 运行容器 docker run -d --name sonarqube-postgres \-p 5432:5432 \-e POSTGRES_DB=sonar_DB \-e POSTGRE…

PostgreSQL删除重复数据同时保留每组中的一条记录

PostgreSQL删除重复数据同时保留每组中的一条记录 在 PostgreSQL 中&#xff0c;你不能直接从一个 CTE&#xff08;公共表表达式&#xff09;中删除数据&#xff0c;因为 CTE 只是一个临时的结果集&#xff0c;它并不直接对应一个可以更新的表。但是&#xff0c;你可以使用 CT…

Nsight Compute 是怎么计算Roofline的呢

Nsight Compute 是怎么计算Roofline的呢 1.参考链接2.小结3.Nsight Compute 是怎么计算Roofline的呢4.生成测试程序5.测试规模为8192时的性能6.计算Roofline7.指标解释8.测试规模为1024时的性能9.测试规模为128时的性能10.RTX 3060基础能力测试11.sm__inst_executed.avg.pct_of…

IPv6测试指标有哪些?怎么看网站是否完成IPv6升级改造?

IPv6是互联网第六代协议&#xff0c;以其近乎无限的地址资源为未来互联网的发展提供了广阔空间和无限可能&#xff0c;为物联网、大数据、人工智能等新基建的蓬勃发展提供了坚实的网络支撑。我国高度重视IPv6的发展建设&#xff0c;自2017年《推进互联网协议第六版&#xff08;…

高性价比蓝牙耳机有哪些?2024超高性价比蓝牙耳机推荐

在2024移动互联网高速发展的时代&#xff0c;蓝牙耳机已成为我们生活中不可或缺的一部分。走在街头&#xff0c;低头看手机&#xff0c;滑动屏幕选歌&#xff0c;耳边传来清晰的旋律&#xff0c;这一幕已经成为现代生活的标配。但面对市场上琳琅满目的蓝牙耳机品牌和型号&#…

数据库同步最简单的方法

数据库同步到底有咩有简单的方法&#xff0c;有肯定是有的&#xff0c;就看你有咩有缘&#xff0c;看到这篇文章&#xff0c;你就是有缘人。众所周知&#xff0c;数据库同步向来都不是一件简单的事情&#xff0c;它很繁琐&#xff0c;很费精力&#xff0c;很考验经验&#xff0…

Kali Linux源

中科大 deb http://mirrors.ustc.edu.cn/kali kali-rolling main non-free contrib deb-src http://mirrors.ustc.edu.cn/kali kali-rolling main non-free contrib阿里云 deb http://mirrors.aliyun.com/kali kali-rolling main non-free contrib deb-src http://mirrors.…

risc-v 怎么使用内存呢?

内存地址对齐 一般写法 #define ALIGN_4_BYTES 4 #define ALIGN_4_MASK (ALIGN_4_BYTES - 1) //4字节地址对齐 static inline uintptr_t align_4_bytes(uintptr_t address) {return (address ALIGN_4_MASK) & ~ALIGN_4_MASK; }//定义页大小是4k&#xff0c;2的12次方是409…

【LeetCode】每日一题:K个一组反转链表

解题思路 其实更像一个模拟题&#xff0c;但是有两个地方的边界一直没有处理好导致卡了很久。 AC代码 # Definition for singly-linked list. # class ListNode: # def __init__(self, val0, nextNone): # self.val val # self.next next class Solut…

力扣 刷题 使用双指针进行数组去重分析

目录 双指针 一、26.删除有序数组中的重复项 题目 题解 二、80. 删除有序数组中的重复项 II 题目 题解 三、27. 移除元素 题目 题解 双指针 我们这里所说的双指针实际上并不是真正的指针&#xff0c;它只是两个变量&#xff0c;用于标识数组的索引等&#xff0c;因其…

vue3封装表格嵌套表单问题汇总

1.插槽嵌套多层数据ui组件怎么使用 思路&#xff1a;插槽具名【区分】后暴露传递&#xff0c;这个为神魔要区分&#xff0c;因为封装组件表格列表项也有插槽 步骤一&#xff1a;表单插槽暴露 <ElFormclass"form-search":model"formParams"ref"form…

java基于ssm+jsp 多人命题系统

1管理员功能模块 管理员登录&#xff0c;管理员通过输入用户、密码等信息进行系统登录&#xff0c;如图1所示。 图1管理员登录界面图 管理员对个人中心进行操作填写原密码、新密码、确认密码并进行添加、删除、修改以及查看&#xff0c;如图2所示。 图2个人信息功能界面图 学…

vue项目连接多个服务后台地址

vue项目连接多个服务器 场景描述&#xff1a;由于公司项目需要基于若依框架和starlingX后台开发&#xff0c;所以&#xff0c;项目至少要连接两个后台地址 在 vue.config.js 文件里 添加一个地址 devServer: {host: "0.0.0.0",port: port,open: true,proxy: {[pro…

台式电脑没有音响?你还可以用这 7 个软件把手机变成音响

台式电脑没有音响&#xff1f;你还可以用这 7 个软件把手机变成音响 怎么让手机当电脑音响 怎么让电脑连接手机的麦克风 手机怎么变电脑麦克风 1.AudioRelay 官网audiorelay加点net提供 Windows 和 Android 应用程序下载 再打开作为 Client 的 Android 端&#xff0c;它会自…

遥感数据并行运算(satellite remote sensing data parallell processing)

文章内容仅用于自己知识学习和分享&#xff0c;如有侵权&#xff0c;还请联系并删除 &#xff1a;&#xff09; 之前不太会用&#xff0c;单纯想记录一下&#xff0c;后面或许还会用到 1. 教程 [1] Pleasingly Parallel Programming: link 1.1 处理器&#xff0c;核和线程 …

申请免费6个月SSL证书方式和证书特点槽点

当前&#xff0c;HTTPS访问已成为网站标配。随着免费证书平台的不断涌现&#xff0c;Lets Encrypt尤为瞩目&#xff0c;其提供的泛域名和多域名证书申请功能&#xff0c;显著降低了站长和企业的经济负担。从一开始&#xff0c;来此加密就支持通过Lets Encrypt申请免费的域名SSL…