Java基础——集合进阶用到的数据结构知识点1

一、数据结构

🌟1.1 数据结构的概述

数据结构(Data Structure) 是指在计算机中组织和存储数据的方式 ,目的是让数据的访问、插入、删除、查找等操作更高效

💡 简单比喻:

  • 数据 = 书
  • 数据结构 = 书架的摆放方式
    • 按字母排 → 查找快(如字典)
    • 随意堆 → 插入快但找起来慢
    • 先进先出的箱子 → 只能从顶部拿(如栈)

好的数据结构 = 让程序又快又省资源!

📦1.2 常见的数据结构

类型 常见结构 特点
线性结构 数组(Array)、链表(Linked List)、栈(Stack)、队列(Queue) 数据按顺序排列
非线性结构 树(Tree)、图(Graph)、堆(Heap) 数据有层次或网络关系
哈希结构 哈希表(Hash Table / HashMap) 通过"键"快速定位"值"

1.2.1 栈

1.2.2 队列

1.2.3 数组

1️⃣ 数组(Array)

✅ 是什么?

  • 连续内存空间 中存储相同类型元素的结构。
  • 通过索引(index) 直接访问任意元素。

🔑 核心特点:

  • 优点:随机访问极快(O(1))
  • 缺点 :大小固定(Java 中可变的是 ArrayList,底层仍是数组)、插入/删除慢(需移动元素)

1.2.4 链表

2️⃣ 链表(Linked List)

✅ 是什么?

  • 节点(Node) 组成,每个节点包含:
    • 数据(data)
    • 指向下一个节点的引用(next)
  • 节点在内存中不要求连续

🔑 核心特点:

  • 优点:插入/删除快(O(1),只需改指针)、动态扩容
  • 缺点:不能随机访问(必须从头遍历,O(n))

🆚1.3 四大结构对比总结

结构 访问方式 插入/删除效率 是否支持随机访问 典型应用场景
数组 索引直接访问 慢(需移动) ✅ O(1) 存储固定/已知数量数据
链表 从头遍历 快(改指针) ❌ O(n) 频繁增删、未知长度
只操作顶部 ✅ O(1) 后退、递归、表达式计算
队列 队首出,队尾入 ✅ O(1) 任务调度、BFS、缓冲

声明:

题目详细分析借鉴于通义AI

以上均来源于B站@ITheima的教学内容!!!

本人跟着视频内容学习,整理知识引用

相关推荐
LO嘉嘉VE5 小时前
学习笔记二十一:深度学习
笔记·深度学习·学习
_OP_CHEN6 小时前
算法基础篇:(二十一)数据结构之单调栈:从原理到实战,玩转高效解题
数据结构·算法·蓝桥杯·单调栈·算法竞赛·acm/icpc
兔子撩架构6 小时前
Dubbo 的同步服务调用
java·后端·spring cloud
代码游侠6 小时前
学习笔记——数据结构学习
linux·开发语言·数据结构·笔记·学习
x***13396 小时前
MySQL 篇 - Java 连接 MySQL 数据库并实现数据交互
java·数据库·mysql
摇滚侠6 小时前
零基础小白自学 Git_Github 教程,发现工具寻找灵感,笔记04
笔记·github
xuanzdhc6 小时前
Gitgit
java·linux·运维·服务器·c++·git
玦尘、7 小时前
《统计学习方法》第4章——朴素贝叶斯法【学习笔记】
笔记·机器学习
风123456789~7 小时前
【健康管理】第4章 常见慢性病 4.7慢阻肺 2/2
笔记·考证·健康管理
无心水7 小时前
【Python实战进阶】7、Python条件与循环实战详解:从基础语法到高级技巧
android·java·python·python列表推导式·python条件语句·python循环语句·python实战案例