Java 数据结构与算法:时间空间复杂度 从入门到实战全解

Java 数据结构与算法:时间空间复杂度 从入门到实战全解
在这里插入图片描述
🏠个人主页:黎雁
🎬作者简介:C/C++/JAVA后端开发学习者
❄️个人专栏:C语言数据结构(C语言)EasyXJAVA数据结构与算法(JAVA)游戏规划程序人生
✨ 从来绝巘须孤往,万里同尘即玉京
在这里插入图片描述


文章目录

在这里插入图片描述

Java 数据结构与算法:时间空间复杂度 从入门到实战全解 🚀

算法入门第一课,吃透复杂度,刷题少走90%弯路!

📝 文章摘要

  • 阅读时长:12 分钟
  • 适合人群
    1. Java 算法零基础初学者 → 重点看:数据结构概念、学习路线、复杂度定义与大O推导
    2. 准备开始刷力扣/剑指Offer 的同学 → 重点看:复杂度分析、实战例题、最优解判断
    3. 面试复习算法基础 → 重点看:复杂度对比、大O规则、时间/空间取舍思想
    4. 写技术博客/做知识复盘 → 重点看:结构逻辑、知识点梳理、表述规范
  • 本文内容:全覆盖数据结构基础认知、算法学习方法、Java 版时间复杂度与空间复杂度、大O表示法、常见复杂度对比,并搭配两道经典 LeetCode 题进行复杂度实战分析,全程 Java 代码、图文清晰、全是干货。

🧠 前置知识回顾

在正式进入数据结构与算法之前,我们已经掌握:

  1. Java 基础语法、数组、循环、方法
  2. Java 集合框架(List、ArrayList 等)
  3. 面向对象、继承、多态、泛型
  4. 简单的代码编写与调试能力

而今天要学习的 数据结构与算法 + 复杂度分析,是所有进阶知识、框架源码、面试算法的基石


一、数据结构与算法基础认知 📚

1. 什么是数据结构?

  • 数据结构(Data Structure):计算机存储、组织和描述数据的方式。
  • 简单理解:数据怎么放、怎么取、怎么查最高效。
  • 在 Java 中:很多常用数据结构已经被 JDK 封装好,就是我们常用的 集合类(ArrayList、LinkedList、HashMap、TreeSet 等)。

2. 数据库 ≠ 数据结构(一定要分清)

  • 数据库:用来持久化存储数据的软件(MySQL、Oracle 等)。
  • 数据结构:数据在内存中的组织方式。
  • 关系:数据库在底层存储数据时,会大量使用数据结构(如索引用 B+ 树)。

3. 数据结构与算法的关系

它们是相辅相成、不可分割的:

  • 数据结构:数据怎么存
  • 算法:数据怎么处理
  • 好算法 + 好结构 = 高效程序

4. 最实用的学习路线(直接照做)

  1. 手写代码 + 画图理解逻辑
  2. IDEA 断点调试,看每一步变化
  3. 写 ZEEKLOG 博客总结
  4. 定期复盘巩固
  5. 刷题提升
    • 《剑指 Offer 第2版 + 专项突破版》
    • LeetCode 热题 Hot100
    • 各类高频面试题
不刷题、不复盘,算法永远学不会!

二、算法复杂度:评价算法好坏的唯一标准 ⚖️

我们写代码,不只要能跑通,还要:

  • 跑得够快(时间)
  • 占内存够小(空间)

衡量这两点的,就是 时间复杂度空间复杂度

1. 两个核心概念

① 时间复杂度 ⏱️

  • 定义:随着输入数据规模 n 增大,代码执行次数的增长趋势
  • 关注:数据量变大后,代码会不会“崩”。
  • 和运行时间无关:不同机器速度不同,只看执行次数

② 空间复杂度 📦

  • 定义:算法运行时,临时占用的额外存储空间n 的增长趋势。
  • 注意:只算临时开辟的空间,不算输入/输出本身占用的空间。

③ 时间 vs 空间:怎么取舍?

  • 早年内存贵:以时间换空间
  • 现在内存充足:以空间换时间(更常用)
  • 企业开发优先:时间效率 > 空间效率

三、大O表示法:复杂度的统一语言 🧮

大O表示法只看增长趋势,不看精确次数,规则只有三句:

  1. 常数项直接去掉
    3 → O(1)
  2. 只保留最高次项
    n² + 5n + 10 → O(n²)
  3. 最高次项系数去掉
    3n² → O(n²)

一句话:只看量级,不看细节!

Java 代码示例:简单复杂度分析

publicclassDemo{publicstaticvoidmain(String[] args){int n =100;int sum =0;// 1次for(int i =0; i < n; i++){ sum += i;// n次}System.out.println(sum);// 1次}}

总次数:1 + n + 1 = n + 2
按规则简化 → O(n)


四、三种情况:最好、最坏、平均

以在数组中找一个数为例:

  • 最好情况:第一个就找到 → O(1)
  • 最坏情况:遍历到最后才找到 → O(n)
  • 平均情况:平均查找 n/2 次 → O(n)

默认都看最坏情况
因为它能给程序性能兜底:再差也不会比这个慢。


五、常见复杂度从快到慢排序(必须背)

复杂度名称速度典型场景
O(1)常数阶极快取值、运算、赋值
O(log n)对数阶极快二分查找
O(n)线性阶单层循环、遍历
O(n log n)线性对数阶较快快排、归并排序
O(n²)平方阶双层循环、冒泡排序
O(2ⁿ)指数阶极慢暴力递归斐波那契
O(n!)阶乘阶最慢暴力全排列

增长速度:

O(1) < O(log n) < O(n) < O(n log n) < O(n²) < O(2ⁿ) < O(n!) 

六、空间复杂度(比时间简单)

只看额外开辟的临时空间

  • O(1):几个固定变量
  • O(n):长度为 n 的数组/集合
  • O(log n):递归深度(如二分递归)
  • O(n²):n×n 二维数组

示例:

// 空间 O(1)int a =10;int b =20;// 空间 O(n)int[] arr =newint[n];

七、LeetCode 经典实战(Java 版)✨

例题1:268. 丢失的数字

题目:给定 [0,n] 中的 n 个数,找缺失的那个数。
要求:时间 O(n),空间 O(1)

思路1:数学求和法(最优)

publicintmissingNumber(int[] nums){int n = nums.length;int sum = n *(n +1)/2;int realSum =0;for(int num : nums){ realSum += num;}return sum - realSum;}
  • 时间:O(n)
  • 空间:O(1)

思路2:异或法(更稳,不溢出)

publicintmissingNumber(int[] nums){int res = nums.length;for(int i =0; i < nums.length; i++){ res ^= i ^ nums[i];}return res;}
  • 时间:O(n)
  • 空间:O(1)

例题2:189. 旋转数组

题目:将数组向右旋转 k 位,原地修改,空间 O(1)

最优解:三次翻转法

publicvoidrotate(int[] nums,int k){int n = nums.length; k %= n;reverse(nums,0, n -1);reverse(nums,0, k -1);reverse(nums, k, n -1);}privatevoidreverse(int[] nums,int left,int right){while(left < right){int temp = nums[left]; nums[left]= nums[right]; nums[right]= temp; left++; right--;}}
  • 时间:O(n)
  • 空间:O(1)

📌 全篇核心干货总结

  1. 数据结构:数据的存储组织方式,Java 中体现为集合类。
  2. 学习路线:写代码 + 画图 + 调试 + 博客 + 复盘 + 刷题(剑指Offer + Hot100)。
  3. 时间复杂度:执行次数的增长趋势。
  4. 空间复杂度:临时额外占用空间的增长趋势。
  5. 大O规则:去常数、去系数、留最高次项。
  6. 复杂度速度
    O(1) > O(log n) > O(n) > O(n log n) > O(n²) > O(2ⁿ)
  7. 企业原则:优先时间,空间换时间。
  8. 两道经典题
    • 丢失的数字:求和法 / 异或法
    • 旋转数组:三次翻转(原地最优)

✍️ 写在最后

数据结构与算法,是程序员的内功
复杂度分析,是判断你代码优不优秀的第一把尺子

从今天开始,写每一段代码都问自己三句:

  • 时间复杂度是多少?
  • 空间复杂度是多少?
  • 还能不能更优?

坚持下去,你会越来越接近“一眼看出最优解”的境界。

本篇是算法系列的开篇奠基之作,下一篇我们正式进入:
线性表 —— 数组、链表、栈、队列 从原理到手写

觉得这篇文章清晰、干货、适合 Java 学习者,欢迎 点赞 👍 收藏 💾 评论 + 关注,持续更新高质量算法博客!

Read more

跨越天堑:机器人脑部药物递送三大技术路径的可转化性分析研究

跨越天堑:机器人脑部药物递送三大技术路径的可转化性分析研究

摘要 血脑屏障是中枢神经系统药物研发最核心的瓶颈。尽管相关基础研究层出不穷,但“论文成果显著、临床转化缓慢”的悖论依然存在。本文认为,突破这一瓶颈的关键在于,将研究重心从“单点机制”转向构建一条“可验证、可复现、可监管”的全链条递送系统。为此,本文提出了一个衡量脑部递送技术可转化性的四维评价标尺:剂量可定义、闭环可监测、质控可标准化、可回退。基于此标尺,本文深度剖析了当前最具潜力的三条技术路径: (1)FUS/低强度聚焦超声联合微泡; (2)血管内可导航载体/机器人; (3)针对胶质母细胞瘤(GBM)的多功能纳米系统。 通过精读关键临床试验、前沿工程研究和系统综述,我们抽离出可直接写入临床或产品方案的核心变量,识别了各自面临的最大转化风险,并提出了差异化的“押注”策略。分析表明,FUS+MB路径因其在“工程控制”上的成熟度,在近期(12-24个月)的转化确定性最高;血管内机器人代表了精准制导的未来趋势,

By Ne0inhk

Stack-Chan机器人完整入门指南:从零开始构建你的可爱机器人伙伴

Stack-Chan机器人完整入门指南:从零开始构建你的可爱机器人伙伴 【免费下载链接】stack-chanA JavaScript-driven M5Stack-embedded super-kawaii robot. 项目地址: https://gitcode.com/gh_mirrors/sta/stack-chan Stack-Chan是一个基于JavaScript驱动的M5Stack嵌入式超级可爱的机器人项目。这个开源项目让你能够轻松构建一个会眨眼、会转头、会说话的智能机器人伙伴。无论你是嵌入式开发新手还是经验丰富的开发者,都能快速上手这个充满乐趣的项目。 🎯 项目核心亮点 超强可爱属性:Stack-Chan拥有多种可爱的面部表情,能够进行眼神交流,让你的机器人充满个性魅力。 模块化设计:项目采用高度模块化的架构,支持多种舵机驱动、面部渲染器和功能扩展,让你的定制变得简单而灵活。 丰富功能生态:支持人脸追踪、语音对话、表情模仿等智能功能,为你的机器人注入灵魂。 📦 项目快速入门 环境准备与代码获取 首先克隆项目仓库到本地: git clone ht

By Ne0inhk
无人机避障——Mid360+Fast-lio感知建图+Ego-planner运动规划(胎教级教程)

无人机避障——Mid360+Fast-lio感知建图+Ego-planner运动规划(胎教级教程)

电脑配置:Xavier-nx、ubuntu 18.04、ros melodic 激光雷达:Livox_Mid-360 结果展示:左边Mid360+Fast-lio感知建图,右边Ego-planner运动规划 1、读取雷达数据并显示 无人机避障——感知篇(采用Livox-Mid360激光雷达获取点云数据显示)-ZEEKLOG博客 看看雷达数据话题imu以及lidar两个话题  2、读取雷达数据并复现fast-lio  无人机避障——感知篇(采用Mid360复现Fast-lio)-ZEEKLOG博客 启动fast-lio,确保话题有输出   由于此处不需要建图,因此不打开rviz,launch文件如下修改: <launch> <!-- Launch file for Livox MID360 LiDAR --> <arg name="rviz&

By Ne0inhk
Ubuntu搭建PX4无人机仿真环境(5) —— 仿真环境搭建(以Ubuntu 22.04,ROS2 Humble,Micro XRCE-DDS Agent为例)

Ubuntu搭建PX4无人机仿真环境(5) —— 仿真环境搭建(以Ubuntu 22.04,ROS2 Humble,Micro XRCE-DDS Agent为例)

目录 * 前言 * 1. 准备 * 1.1 下载 PX4 源码 * 方式一: * 方式二: * 1.2 安装仿真依赖 * 1.3 安装 Gazebo * 2. 安装 Micro XRCE-DDS Agent * 3. 编译 PX4 * 4. 通信测试 * 5. 官方 offboard 程序 * 6. offboard 测试 * 参考 前言 本教程基于 ROS2 ,在搭建之前,需要把 ROS2、QGC 等基础环境安装配置完成。但是这块的资料相比较于 ROS1 下的少很多,不利于快速上手和后期开发,小白慎选! 小白必看:

By Ne0inhk