最值得收藏的数据结构与算法学习路线

本文涉及的产品
RDS AI 助手,专业版
RDS Agent(兼容OpenClaw),2核4GB
PolarDB Agent Express,2核4GB
简介: 数据结构与算法学习路线

说出来还真有点不好意思。上学那时候傻,为了校招,硬着头皮刷《算法导论》、《编程珠玑》,还有 LeetCode,刷了小一年。

等找到了工作后才恍然大悟,原来当初根本不用那么辛苦。这不,刚好有小伙伴在《二哥的Java进阶之路》知识星球上问我算法的学习路线,我就毫不保留地把我算法方面的学习经验分享出来,希望能给大家一点点启发和帮助。

我画了一张图,里面几乎涵盖了所有数据结构与算法书籍中都会讲到的知识点。

但讲良心话,对于一个初学者,或者不打算卷算法岗的程序员来说,完全就没必要把思维导图里面的所有知识点都学了,那样就太不高效了。

我们学习数据结构与算法,也得讲究策略。我的建议是这样的(敲黑板、划重点了啊):

7 个数据结构:

数组
链表

队列
哈希表
二叉树

10 个算法:

递归
排序
二分查找
搜索
哈希算法
贪心算法
分治算法
回溯算法
动态规划
字符串匹配算法
这些是学习数据结构与算法时的重点。很多人在第一次接触数据结构与算法这门课时,往往会觉得很抽象,很难搞懂,以至于站在门外徘徊不前。

其实真正的原因是没有找到好的学习方法,没有抓住学习的重点。相信你认真看完我这条学习路线后,学起来就会有的放矢、事半功倍了。

一、什么是数据结构

数据结构是一种具有一定逻辑关系,在计算机中应用某种存储结构,并且封装了相应操作的数据元素集合。它包含三方面的内容,逻辑关系、存储关系及操作。不同种类的数据结构适合于不同种类的应用,而部分甚至专门用于特定的作业任务。例如,计算机网络依赖于路由表运作,B 树高度适用于数据库的封装。

简单点说,数据结构就是把一堆数据,按照某种格式揉成一坨。

大家喜欢吃宫保鸡丁吗?

反正二哥挺喜欢这道菜的。我就以宫保鸡丁为例,来讲一讲数据结构吧。维基百科上是这样定义的。

宫保鸡丁(英语:Kung Pao chicken或Kung-Pao Chicken),又称宫爆鸡丁,呈糊辣荔枝味,源于黔菜、流传至鲁而后成于川菜的一道川味名菜。贵州、山东和四川三地对这道菜的做法不完全一样,称呼也有差异。贵州称为糊辣子鸡丁,山东则名为酱爆鸡丁,而四川是以宫保鸡丁为名的。

来,抽象下宫保鸡丁。

struct KungPaoChicken {
鸡肉 = []
花生 = []
葱段 = []
花椒 = []
辣椒 = []
}
这个结构体(struct 是 C 语言中的一个概念)就是一个自定义的数据结构,将很多不同的配料融合在了一起。对于计算机的数据结构来说,只不过是把这些配料换成了基本数据类型。

抽象完宫保鸡丁再来抽象一下二哥吧。

class 二哥 {
int age = 18;
double 体重 = 65kg;

void eat(宫保鸡丁) {
体重 += 1kg;
}
}
伪代码不是很严谨哈,大家理解这个意思就行了。

说到底,数据结构不过是一种抽象后的封装。像 Java,它之所以流行的一个很重要的原因,就是它提供了多种多样的、方便开发者调用的数据结构,比如说对数组的封装 ArrayList、对链表的封装 LinkedList、对哈希表的封装 HashMap、ConcurrentHashMap 等等。C 语言就没有这些,想用的话,就得自己封装。但 Java 和 C 语言的基本数据类型是一致的,int、float 这些都是相通的。

对于初学者来说,平常敲代码都是直接去调用数据结构的,是很少去想这些数据结构是怎么实现的。

当一个初学者向高级程序员迈进的时候,就必须得静下心来,去搞清楚 ArrayList 和 LinkedList 的内部实现,搞清楚之后就会明白,之所以它们在增删改查的时候性能上有差异,就是因为它们的内部使用了不同的数据结构所导致的。

经典的数据结构与算法都有哪些呢?比如说队列、栈、堆、二分查找、动态规划等等。

二、什么是算法

算法就是操作数据的一组方法。数据结构是为算法服务的,而算法想要体现出自己的价值,就必须得有数据结构这个载体。

它们俩就好像是一对恋人,离开了谁,都会孤单寂寞冷。

那一些初学者可能会有这样的疑惑:我数学成绩一般,学数据结构与算法会很吃力吗?

当然了,数据结构和算法离不开一些数学方面的推理和证明,比如说我们在分析某个算法的时间复杂度和空间复杂度时。但这个不需要去担心,只要你能保持高中时期的数学水准,就完全可以学好数据结构与算法。

三、为什么要学习数据结构和算法

你是不是觉得数据结构与算法,跟操作系统、计算机网络一样,都是脱离实际工作的知识,可能除了面试,这辈子都用不着?

就算不懂数据结构与算法,照样可以把 Java API、开发框架用得飞起?

首先,面试的确是要考数据结构与算法的。这是很多大厂的筛选要素之一。

这是因为校招的时候,参加面试的学生大多数都是没有实际项目经验的,公司只能通过考察这些基础知识来筛选。

大厂不怕你没有项目经验,而怕你没有长期发展的潜力。

所以,很多参加校招的同学,在面试前都会疯狂刷题的,至少会突击个 100 道左右的题目。

其次,实际工作当中肯定是会用到的。

举个例子,存储某个业务数据时,你打算用 ArrayList 还是 LinkedList,它们底层用的是哪种数据结构,增删改查上有哪些优缺点?

再比如,Redis 中的有序集合是用什么数据结构实现的?为什么要用跳表二不是二叉树呢?

不懂数据结构和算法,行得通吗?

还有,掌握了数据结构与算法,对阅读源码会有很大的帮助,因为很多时候,源码当中都会考量到不同数据结构之间的优点和缺点。

你比如说,HashMap 为什么在链表长度大于 8 的时候将其转为红黑树?为什么不能是二叉树?

总结一下。

我们学习数据结构与算法,并不是为了死记硬背几个知识点,我们的目的是建立时间复杂度、空间复杂度的意识,写出高质量的代码,提升编程技能,训练逻辑思维,从而获得更高的薪资回报。

为什么要学习数据结构与算法,我认为 3 点很重要:

1、写出性能更佳的代码。
2、算法是求解问题的计算步骤,而程序是用计算机可以理解的语言来描述的算法。
3、长期来看,思考能力是一个人非常重要的核心竞争力,而算法是为数不多能训练思考能力的途径之一。

是时候提升自己的内功了,这样怼人也会更自信,跳槽也不用畏畏缩缩了。

四、硬核算法和数据结构学习资料

1)视频

B 站上浙江大学的一个数据结构课非常不错,很系统很经典。每次看这些大学老师的讲课就越觉得考好大学很重要,很多学校的老师,在讲数据结构和算法的时候,自己都不知道自己在讲什么。

不得不说,陈越姥姥等人对数据结构和算法这个领域的知识理解是真的透彻,我在听这个课的时候感觉整个人都通透了。

视频地址:https://www.bilibili.com/video/BV1Kb41127fT

这里还有个同学在 GitHub 上整理这门课程的所有课件和作业,学习 Java 的小伙伴可以尝试用 Java 完成下作业。

GitHub 地址:https://github.com/CYBruce/DataStructure_Algorithm_ZJU

#2)书籍
入门阶段推荐陈小玉老师的《趣学数据结构》和《趣学算法》。

算法领域的经典参考书《算法 4》也非常值得推荐,里面的代码是用 Java 实现的,所以 Java 开发者可以直接选用这本书。

学霸型人才可以直接刷《算法导论》,严谨全面,可以直接拿来作为研究生阶段的算法课程教材。

#3)开源电子书
算法方面的开源电子书是真的非常多,这里推荐下《labuladong 的算法小抄》,仓库里面有句话我非常认同——“刷题刷题,刷的是题,培养的是思维”,这个仓库的优势就在于,它的解题思路很完备,我相信可以帮助到不少读者,至少在刷题的时候少走很多弯路。

目录
相关文章
|
1月前
|
IDE 开发工具 iOS开发
JetBrains IDE 2026.1 (macOS, Linux, Windows) - 跨平台开发者工具
JetBrains IDE 2026.1 (macOS, Linux, Windows) - 跨平台开发者工具
141 7
JetBrains IDE 2026.1 (macOS, Linux, Windows) - 跨平台开发者工具
|
Web App开发 搜索推荐 机器人
真假搜索引擎蜘蛛IP地址和UA(UserAgent)大全
真假搜索引擎蜘蛛IP地址和UA(UserAgent)大全 这些信息不是一直不变的,这里仅供参考。
2300 0
真假搜索引擎蜘蛛IP地址和UA(UserAgent)大全
|
测试技术 数据库 uml
【软件工程与UML】第2章 用例图、用例文档、活动图 -- 系统的功能需求建模
【软件工程与UML】第2章 用例图、用例文档、活动图 -- 系统的功能需求建模
1497 0
【软件工程与UML】第2章 用例图、用例文档、活动图 -- 系统的功能需求建模
|
数据采集 人工智能 自动驾驶
《突破AI数据标注高成本枷锁,势在必行!》
在人工智能快速发展的背景下,数据标注作为AI模型训练的基础,其高成本问题成为制约行业发展的关键因素。主要体现在人力、时间和管理成本上,尤其是在复杂领域和大规模数据处理中。为解决这一难题,行业探索了多种创新方案:技术层面,自动化标注工具与半监督学习技术显著提升效率;商业模式上,分布式众包和专业平台降低运营成本;人才培养方面,校企合作与激励机制优化标注质量。尽管仍存挑战,但通过多方协同,有望推动AI数据标注行业的高效发展,助力AI技术广泛应用。
614 9
|
存储 人工智能 自然语言处理
基于QwQ-32B+Hologres+PAI搭建 RAG 检索增强对话系统
本文介绍如何使用PAI-EAS部署基于QwQ大模型的RAG服务,并关联Hologres引擎实例。Hologres与达摩院自研高性能向量计算软件库Proxima深度整合,支持高性能、低延时、简单易用的向量计算能力。通过PAI-EAS,用户可以一键部署集成大语言模型(LLM)和检索增强生成(RAG)技术的对话系统服务,显著缩短部署时间并提升问答质量。具体步骤包括准备Hologres向量检索库、部署RAG服务、通过WebUI页面进行模型推理验证及API调用验证。Hologres支持高性能向量计算,适用于复杂任务的动态决策,帮助克服大模型在领域知识局限、信息更新滞后和误导性输出等方面的挑战。
|
自然语言处理 数据可视化 数据挖掘
Agent实操(四):Code Interpreter,生成二维码、视频、PDF转txt等炸裂功能
本文介绍Agent自带的Code Interpreter有哪些高级而实用的能力
Agent实操(四):Code Interpreter,生成二维码、视频、PDF转txt等炸裂功能
|
SQL Arthas 运维
取经阿里十年技术大佬,得到Java线上问题排查攻略!
再牛逼的程序员都写不出完美无缺的代码,作为后端开发工程师,一不小心就会遇到线上故障。如果线上故障处理不及时,就可能导致各种严重的后果。恰好最近部门出现了一次挺严重但幸运的是影响面不大的线上故障,最后在阿里工作十年的leader分享了线上问题的排查思路。结合这次分享,写下了这篇Java线上问题排查攻略。
确保你已经安装了`python-barcode`库。如果没有,可以通过pip来安装:
确保你已经安装了`python-barcode`库。如果没有,可以通过pip来安装:
|
开发框架 Java 测试技术
Spring Boot 项目中使用 `@Autowired` 注解,合理吗?
Spring Boot 项目中使用 `@Autowired` 注解,合理吗?
526 1
Spring Boot 项目中使用 `@Autowired` 注解,合理吗?
|
前端开发 开发者 容器
【专栏:CSS进阶篇】CSS Flexbox布局:实现灵活的响应式设计
【4月更文挑战第30天】CSS Flexbox是现代网页设计中创建响应式布局的关键工具,它提供了一种一维布局模型,使元素能灵活适应各种屏幕尺寸。通过设置容器的`display`属性为`flex`,开发者可以利用主轴和交叉轴调整元素排列和对齐方式。核心概念包括弹性项、伸缩性、空间分配和对齐。通过实例,如导航栏、卡片布局、图片画廊和响应式表单,展示了Flexbox在实现响应式设计中的应用。尽管需要注意浏览器兼容性,但掌握Flexbox能帮助开发者构建出功能强大且适应性强的界面。
403 0