很多人看到我的博客,太多专栏不知道从何学起,为了广大人民群众的根本利益,我决定写一个阅读指引,按照这个指引进行学习,多加练习,假以时日,势必能够……算了,还是看你自己能学多少以及能够坚持到哪里了。加油吧,少年!坚持就是胜利!迈出第一步就成功了一半!
专栏 | 定位 | 适宜人群 |
---|---|---|
「 光天化日学C语言 」 | 「 入门 」 | 没有任何语言基础 |
「 LeetCode零基础指南 」 | 「 初级 」 | 零基础快速上手力扣 |
「 C语言入门100例 」 | 「 中级 」 | 零基础持续C语言练习教程 |
「 算法零基础100讲 」 | 「 高级 」 | 零基础持续算法练习教程 |
「 画解数据结构 」 | 「 高级 」 | 「 推荐 」 数据结构动图教程 |
「 算法进阶50讲 」 | 「 资深 」 | 进阶持续算法练习教程 |
「 LeetCode算法题集汇总 」 | 「 资深 」 | 全面的力扣算法题练习集锦 |
「 夜深人静写算法 」 | 「 资级 」 | 竞赛高端算法集锦 |
学习算法,还是需要有一门语言作为基础的,推荐用 C语言,并且可以看下这个专栏,了解一些简单的 C语言语法。虽然没有更新完,但是只要看前五节内容,就能够对 C语言 的语法大体有一个了解。
读完这五节,基本能够了解 C语言 的输入输出 了。对于初学者来说,可以先看这么几节,然后我们继续看下面的内容,等遇到相关知识点时再回来翻开即可。
光看不练肯定是不行的,所以主要还是要刷题,我这里推荐的是 LeetCode,主要原因是因为现在一些大厂面试的时候基本都是在 牛客 或者 LeetCode 上找的题,而 LeetCode 上的题更加系统,如果这里的题能够掌握大部分,那面试刷题这快肯定是不慌了。当然,对于竞赛选手,这个难度肯定是远远不够的。不过,这是后话了,我们先来看简单的。
一开始刷题的时候,一定要刷水题。刷水题是为了让你养成刷题的习惯,一开始就刷难题很容易被劝退。刚开是的时候,建立信心是很重要的事情。
建立信心的过程是需要逐渐培养的,通过不断刷题,把题目数量提上来,才能不断的建立信心。所以,很多时候,如果遇到题目告诉你一定要用某个方法来做,但是你又想不出来的时候,你就想办法先把它过掉再说。
例如,下面这道题:
实现一个函数
multiply
,不使用 * 运算符, 实现两个正整数的相乘。可以使用加号、减号、位移,但要吝啬一些。
int multiply(int A, int B){ // (1)
return A * B; // (2)
}
int
是C/C++中的一种类型,代表整数,即 Integer,传入参数是两个整数;*
,那如果我用了会怎么样?答案是并不会怎么样,因为平台不会去对它做语法分析,只是调用了你的函数,提供一些输入数据,如果输出数据和它给定的相同,就算通过。作为你接触算法的第一道题,其实这些条件都无所谓的,能过就行,他只检测输入输出,不检测你实际代码。对于新人来说,把问题过掉比问题本身更重要,题数的增加,是信心的增加,信心比什么都重要,有了信心,你才能继续往下走,只要你能往下推进,你就能继续学习,继续学习你迟早会学到相应的算法。好了,过了这题以后,把这道题放入你的重刷列表,等你对算法有一定理解以后再来用题目要求的方法来过了它。
这个专栏主要讲解了一些 LeetCode 刷题时的一些难点和要点,主要分为以下几个章节,并且会持续补充一些方法论的文章。文章有试读,可以简单先看一看试读文章。
这个专栏的目的是加深对 C语言 的理解,通过看题做题,不断加深每个语法以及简单算法的作用。
该专栏每个算法都会提供例题,并且要求玩家实现一个函数,主函数需要自己写,示例如下:
#include // (1) 标准输入输出库
int add(int a, int b) {
return a + b; // (2) 这就是一个最简单的算法:加法算法
}
int main() {
int a = add(1, 3); // (3) 算法输入两个参数,输出一个参数;
printf("%d\n", a); // (4) 将算法结果输出到屏幕上来验证结果
return 0;
}
试读文章如下,可以看下是否满足自身需要:
如果你只是想学会写代码,或许 「 算法与数据结构 」 并不是那么重要,但是,想要进一步发展自己的事业,「 算法与数据结构 」 是必不可少的。
现在一些主流的大厂,诸如:字节、网易、腾讯、阿里、美团、京东、滴滴 等等,在面时都会让候选人写一道 「 算法题 」 ,如果你敲不出来,可能你的 「 offer 」 年包就打了骨折,或者直接与 「 offer 」 失之交臂,都是有可能的。
当然,它不能完全代表你的 「 编码能力 」 ,因为有些算法确实是很巧妙,加上紧张的面试氛围,想不出来其实也是正常的,但是你能确保面试官是这么想的吗?我们要做的是 「 十足的准备 」 ,既然决定出来, 「 offer 」 当然是越高越好,毕竟大家都要养家糊口,房价又这么贵,如果能够在算法这一块取得先机,也不失为一个 「 捷径 」 。
所以,你问我算法和数据结构有什么用?我可以很明确的说,和你的年薪息息相关。当然,面试中 「算法与数据结构」 知识的考察只是面试内容的一部分。其它还有很多面试要考察的内容,当然不是本文主要核心内容,这里就不做展开了。试读内容如下:
本专栏适宜对算法没有什么概念,但是对某一门语言有一些简单基础的同学,如果语言基础较为薄弱,建议先选择一门语言学习一段时间。当然,如果直接开始学算法,也不是不可以,只要坚持把该专栏的 100 讲 攻克完毕,基本上语言那关也可以过了。
以动图的形式,更加生动形象的阐释每个数据结构的思想和实现。
线性表 和 树 的内容已经大致更新完毕,图相关的内容目前还未更新。已更新内容如下:
这一部分主要是给有大块时间,并且想自学成才的同学准备的,里面的题集也在不断完善整理中。
这个专栏是我五年前写的,有一定难度,但是对于竞赛的同学是个不错的选择。
作者在此承诺!只要你不舍,我不弃,你我同心协力,以三年为期,引万人之势气,共筑未来美好三年!三年之后,算法刷满 1000 题,你我字节见,你不来,我不走!
语言入门:《光天化日学C语言》(示例代码)
语言训练:《C语言入门100例》试用版
数据结构:《画解数据结构》源码
算法入门:《算法入门》指引
算法进阶:《夜深人静写算法》算法模板