当前位置: 首页 > news >正文

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的教学内容!!!

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

http://www.dtcms.com/a/585147.html

相关文章:

  • 无线交换机(AC)核心技术详解:构建集中式Wi-Fi网络的基石
  • DNS的正向、反向解析的服务配置知识点及实验
  • 庖丁解牛:深度剖析 Ascend C 算子开发流程与核心概念
  • 《Learn Python Programming(4th)》读后感
  • 网站开发毕业生报告网页设计与制作项目教程陈义文
  • SSM基于JAVA的物流管理系统ztwfg(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • 如何在 Ubuntu 上安装 PostgreSQL
  • openssl-1_0_0-1.0.2p-3.49.1.x86_64.rpm 怎么安装?CentOS/RHEL 手动安装RPM包详细步骤
  • C++ 面试高频题 链表 模拟 力扣 143. 重排链表 题解 每日一题
  • 快速定位bug,编写测试用例
  • 力扣第 474 场周赛
  • Node与Npm国内最新镜像配置(淘宝镜像/清华大学镜像)
  • 超越时空网上书城网站建设方案网站人员队伍建设落后
  • 海外云手机是指什么
  • react native 手搓数字键盘
  • 算法复杂度解析:时间与空间的衡量
  • 开源鸿蒙SIG-Qt技术沙龙成都站成功举办,产品方案展示
  • 2025年渗透测试面试题总结-235(题目+回答)
  • C语言进阶:深入理解函数
  • 计算机图形学·11 变换(Transformations)
  • Rust编程学习 - 如何利用代数类型系统做错误处理的另外一大好处是可组合性(composability)
  • LocalAI:一个免费开源的AI替代方案,让创意更自由!
  • 深入理解Ext2:Linux文件系统的基石与它的设计哲学
  • 泉州网站的建设html网页制作我的家乡
  • PHP 魔术常量
  • 【iOS】音频与视频播放
  • php通过身份证号码计算年龄
  • 基于PHP+Vue+小程序快递比价寄件系统
  • Next.js、NestJS、Nuxt.js 是 **Node.js 生态中针对不同场景的框架**
  • 牛客周赛 Round 114 Java题解