【英雄哪里出来】一文带你吃透算法

文章目录

  • 前言
  • 一、语言基础
    • 1、「 光天化日学C语言 」
  • 二、刷题必读
    • 1、「 LeetCode零基础指南 」
  • 三、语言入门
    • 1、「 C语言入门100例 」
  • 四、算法入门
    • 1、「 算法零基础100讲 」
  • 五、算法进阶
    • 1、「 画解数据结构 」
    • 2、「 算法进阶50讲 」
    • 3、「 LeetCode算法题集汇总 」
    • 4、「 夜深人静写算法 」
  • 六、「 三年之约 」
  • 七、配套赠送福利

前言

  很多人看到我的博客,太多专栏不知道从何学起,为了广大人民群众的根本利益,我决定写一个阅读指引,按照这个指引进行学习,多加练习,假以时日,势必能够……算了,还是看你自己能学多少以及能够坚持到哪里了。加油吧,少年!坚持就是胜利!迈出第一步就成功了一半!

专栏 定位 适宜人群
「 光天化日学C语言 」 「 入门 」 没有任何语言基础
「 LeetCode零基础指南 」 「 初级 」 零基础快速上手力扣
「 C语言入门100例 」 「 中级 」 零基础持续C语言练习教程
「 算法零基础100讲 」 「 高级 」 零基础持续算法练习教程
「 画解数据结构 」 「 高级 」 「 推荐 」 数据结构动图教程
「 算法进阶50讲 」 「 资深 」 进阶持续算法练习教程
「 LeetCode算法题集汇总 」 「 资深 」 全面的力扣算法题练习集锦
「 夜深人静写算法 」 「 资级 」 竞赛高端算法集锦

一、语言基础

1、「 光天化日学C语言 」

  学习算法,还是需要有一门语言作为基础的,推荐用 C语言,并且可以看下这个专栏,了解一些简单的 C语言语法。虽然没有更新完,但是只要看前五节内容,就能够对 C语言 的语法大体有一个了解。

光天化日学C语言

(01)- 初始 C 语言
(02)- 配本地环境
(03)- 变量初体验
(04)- 格式化输出
(05)- 格式化输入

  读完这五节,基本能够了解 C语言 的输入输出 了。对于初学者来说,可以先看这么几节,然后我们继续看下面的内容,等遇到相关知识点时再回来翻开即可。


二、刷题必读

  光看不练肯定是不行的,所以主要还是要刷题,我这里推荐的是 LeetCode,主要原因是因为现在一些大厂面试的时候基本都是在 牛客 或者 LeetCode 上找的题,而 LeetCode 上的题更加系统,如果这里的题能够掌握大部分,那面试刷题这快肯定是不慌了。当然,对于竞赛选手,这个难度肯定是远远不够的。不过,这是后话了,我们先来看简单的。

1、「 LeetCode零基础指南 」

  一开始刷题的时候,一定要刷水题。刷水题是为了让你养成刷题的习惯,一开始就刷难题很容易被劝退。刚开是的时候,建立信心是很重要的事情。
  建立信心的过程是需要逐渐培养的,通过不断刷题,把题目数量提上来,才能不断的建立信心。所以,很多时候,如果遇到题目告诉你一定要用某个方法来做,但是你又想不出来的时候,你就想办法先把它过掉再说。
  例如,下面这道题:

  实现一个函数multiply,不使用 * 运算符, 实现两个正整数的相乘。可以使用加号、减号、位移,但要吝啬一些。

int multiply(int A, int B){   // (1)
    return A * B;             // (2)
}
  • ( 1 ) (1) (1) 这里int是C/C++中的一种类型,代表整数,即 Integer,传入参数是两个整数;
  • ( 2 ) (2) (2) 题目要求返回两个整数的乘积,并且要求不能用*,那如果我用了会怎么样?答案是并不会怎么样,因为平台不会去对它做语法分析,只是调用了你的函数,提供一些输入数据,如果输出数据和它给定的相同,就算通过。作为你接触算法的第一道题,其实这些条件都无所谓的,能过就行,他只检测输入输出,不检测你实际代码。

  对于新人来说,把问题过掉比问题本身更重要,题数的增加,是信心的增加,信心比什么都重要,有了信心,你才能继续往下走,只要你能往下推进,你就能继续学习,继续学习你迟早会学到相应的算法。好了,过了这题以后,把这道题放入你的重刷列表,等你对算法有一定理解以后再来用题目要求的方法来过了它。

  这个专栏主要讲解了一些 LeetCode 刷题时的一些难点和要点,主要分为以下几个章节,并且会持续补充一些方法论的文章。文章有试读,可以简单先看一看试读文章。

LeetCode零基础指南

(第一讲)导读
(第二讲)函数
(第三讲)循环
(第四讲)数组
(第五讲)指针
(第六讲)排序
(第七讲)贪心
(第八讲)矩阵
(第九讲)二级指针
(第十讲)简单递归


三、语言入门

1、「 C语言入门100例 」

  这个专栏的目的是加深对 C语言 的理解,通过看题做题,不断加深每个语法以及简单算法的作用。

C语言入门100例

  该专栏每个算法都会提供例题,并且要求玩家实现一个函数,主函数需要自己写,示例如下:

#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;
}

  试读文章如下,可以看下是否满足自身需要:

【第01题】A + B | 基础输入输出,开启学习C语言打卡的序章
【第02题】给定 n,求 1 + 2 + 3 + .... n-1 + n 的和 | 四种解法


四、算法入门

1、「 算法零基础100讲 」

算法零基础100讲

  如果你只是想学会写代码,或许 「 算法与数据结构 」 并不是那么重要,但是,想要进一步发展自己的事业,「 算法与数据结构 」 是必不可少的。
  现在一些主流的大厂,诸如:字节、网易、腾讯、阿里、美团、京东、滴滴 等等,在面时都会让候选人写一道 「 算法题 」 ,如果你敲不出来,可能你的 「 offer 」 年包就打了骨折,或者直接与 「 offer 」 失之交臂,都是有可能的。
  当然,它不能完全代表你的 「 编码能力 」 ,因为有些算法确实是很巧妙,加上紧张的面试氛围,想不出来其实也是正常的,但是你能确保面试官是这么想的吗?我们要做的是 「 十足的准备 」 ,既然决定出来, 「 offer 」 当然是越高越好,毕竟大家都要养家糊口,房价又这么贵,如果能够在算法这一块取得先机,也不失为一个 「 捷径 」
  所以,你问我算法和数据结构有什么用?我可以很明确的说,和你的年薪息息相关。当然,面试中 「算法与数据结构」 知识的考察只是面试内容的一部分。其它还有很多面试要考察的内容,当然不是本文主要核心内容,这里就不做展开了。试读内容如下:

导读
(第1讲) 幂和对数
(第2讲) 数列

  本专栏适宜对算法没有什么概念,但是对某一门语言有一些简单基础的同学,如果语言基础较为薄弱,建议先选择一门语言学习一段时间。当然,如果直接开始学算法,也不是不可以,只要坚持把该专栏的 100 讲 攻克完毕,基本上语言那关也可以过了。

五、算法进阶

1、「 画解数据结构 」

  以动图的形式,更加生动形象的阐释每个数据结构的思想和实现。

画解数据结构

  线性表 和 树 的内容已经大致更新完毕,图相关的内容目前还未更新。已更新内容如下:

顺序表
链表
队列
双端队列
哈希表
二叉树
二叉搜索树
平衡二叉树

2、「 算法进阶50讲 」

算法进阶50讲》筹备中

3、「 LeetCode算法题集汇总 」

  这一部分主要是给有大块时间,并且想自学成才的同学准备的,里面的题集也在不断完善整理中。

算法入门指引



在这里插入图片描述
在这里插入图片描述

4、「 夜深人静写算法 」

  这个专栏是我五年前写的,有一定难度,但是对于竞赛的同学是个不错的选择。

夜深人静写算法

夜深人静写算法》总纲

  以下是几篇优质文章的试读:
夜深人静写算法(十九)- 背包总览
夜深人静写算法(二十三)- 最短路
夜深人静写算法(二十六)- 记忆化搜索

六、「 三年之约 」

  作者在此承诺!只要你不舍,我不弃,你我同心协力,以三年为期,引万人之势气,共筑未来美好三年!三年之后,算法刷满 1000 题,你我字节见,你不来,我不走!

七、配套赠送福利

语言入门:《光天化日学C语言》(示例代码)
语言训练:《C语言入门100例》试用版
数据结构:《画解数据结构》源码
算法入门:《算法入门》指引
算法进阶:《夜深人静写算法》算法模板

你可能感兴趣的:(《面试资源整合》,算法,面试)