labuladong
由于 labuladong 的算法网站频繁被攻击,且国内访问速度可能比较慢,所以本站同时开放多个镜像站点:
https://labuladong.gitee.io/algo/
https://labuladong.github.io/algo/
这两个站点的内容都是一样的,你可以自行选择访问速度较快的站点开始学习。
PC 端请收藏上述网站地址;手机端请关注 labuladong 公众号阅读最新文章,另外《labuladong 的算法小抄》已出版,关注公众号可获取最新折扣信息:
本网站目前可以手把手带你解决 200 道 LeetCode 算法问题,而且在不断更新,全部基于 LeetCode 的题目,涵盖了所有题型和技巧,我已经把在每篇文章的开头加上了该文章可以解决的 LeetCode 题目链接,可以看完文章立即去拿下对应题目。
另外,配合我的刷题插件和 PDF 教材在本站学习的体验会更好,比如如果你习惯在英文版 LeetCode 刷题,可以通过 刷题插件 将本站所有题目链接改为 LeetCode 的链接。
插件和配套 PDF 的下载方法见这里: labuladong 的刷题三件套正式发布。
关于我
简单介绍一下我自己,我应该是 2018 年就开始刷算法题,顺便开通了自己的公众号,诞生了 labuladong 这个昵称,之后就一直在算法领域持续输出,2020 年在 GitHub 开源了算法仓库 fucking-algorithm,没想到火遍了全网,一年过去了,现在这个仓库已经快有 100k star 了。
由于这个仓库的火爆,有很多出版社找来寻求出版,我在去年年底出版了纸质书《labuladong 的算法小抄》,销量一直非常稳定,为了感谢公众号读者一直以来的支持,我把公众号的大部分文章放到了网站上,方便大家学习。
众所周知现在技术岗面试内卷严重,算法基本上是必考项目了,我知道很多人对算法并不是真爱,所以被算法搞得很头痛。
我也是这样过来的,但靠着自己的努力和一些技巧,在毕业秋招斩获了 13 个 offer,你随便说一个大厂,我都拿到了 offer。
说这些,不是凡尔赛,说实话刷个题面个试真的不算啥,我身边的大佬也比较多,比找工作难的事情多着呢。
我想说的是,其实刷题也好,面试也好,都是有技巧的,我希望把我的技巧和经验分享给大家。如果你有刷算法题的需求觉得算法难,面试笔试难,那么我可以提供一些捷径,避免你走太多弯路。
另外,我奉行的原则是「少即是多」,致力于提高「知识密度」而不是文章数量。
举个简单的例子,你可以看到很多算法相关的博客/仓库,动辄有四五百篇文章,每篇文章其实就是一道题的解法代码 + 三言两语的注释甩在那里,你也许能看懂,但很难做到举一反三,真正会做那一类题目。
而我会严格限制文章数量的增长,把精力放在提高单篇文章质量上面,我称之为「知识密度」。随着我自己不断刷题和思考,如果觉得某篇历史文章的知识密度不够高,那么我会毫不犹豫地下架历史文章,重新构思和发布一篇更干,更通用的新文章。
学习算法可能遇到的问题
1、题太多,不知道从哪里开始刷。
现在 LeetCode 已经 2000 多道题目了,难道我要全部刷完,才算搞定算法了吗?
我应该怎么刷题?按题号一道道刷?按分类刷?听说动态规划相关的问题经常出现,干脆直接开始刷动态规划问题?
我理解大家这种急切的心情,但是在刷最热门的类型之前,有一些必要的前置知识,如果你不掌握的话,很可能一脸懵逼;但如果按照一定的章法掌握之后,就能找到抓手,成功赋能,轻易地打出一套算法组合拳(手动滑稽)。
2、没有人指导,刷一道题就仅仅是刷了一道题而已,很难举一反三。
这是很多朋友都存在的问题,尤其是在刚开始刷题的时候,很难在做完一道题后总结出一些通用的技巧,在遇到新的问题时运用出来,所以很多读者调侃自己「一看都会,一做就废」。
不需要气馁,在刚刚刷题的过程中,积累的算法技巧有限,难以举一反三很正常。但如果有人能够给一些思路上的引导,会让你学习算法的效率事半功倍。
3、被有意无意地灌输错误的思想,以为算法很高大上,非要啃完算法导论才算是入门,所以从心理上就畏惧算法。
我对这个问题有切身体会,刚学算法那会儿,我会去搜索过各种资料、经验贴之类的,想快速入门。
现在回头在看,就觉得很有意思,我是说很多写经验贴的作者心态很有意思。
举个例子,很多「大佬」,你问他怎么入门算法,他告诉你看《算法导论》,然后又甩给你一堆英文课程,还强调一定要看英文的哦,中文的翻译不好。
这就好比,你是一个胖子,去问人家怎么减肥,人家告诉对方,每次做 100 个俯卧撑,100 个引体向上,一天三次,肯定有效,你看我就是这样练出来的!
呵呵,我要是真能做到这些,还用得着来问你么?不过你仔细琢磨琢磨,给出这种回答是基于一种什么心理?
实际上他根本不在乎你的诉求,他只是想告诉你:我做过这些,我吃过这些苦,我牛逼吧,我厉害吧,你羡慕吧,你做不到吧~
不过话说回来,这种小九九人皆有之,我也不例外,我也时不时想证明自己牛,想证明自己和别人不一样,我以前做分享,也会多少有点故弄玄虚的倾向。
但后来我发现,真正帮助别人解决问题,是更能得到对方的认可的,这也是我的公众号能够很快成长的原因。
所以大家可以放心,我的这份教程是「老少皆宜」,非常接地气的,最能解决学习算法这个问题的。
都说算法难,到底难在哪里
1、技巧较多,难以整活儿
各种算法技巧确实比较繁杂,初学者很容易碰到没见过的技巧,碰到时就大呼牛逼,觉得自己菜。比如说判断一个单链表是否成环的算法,一般人确实很难想到。
这也是为什么我说一开始刷算法题不要死磕,因为技巧储备还不够。
比如现在出一道数组的题目,你的脑海里能浮现出什么算法技巧?最起码应该想到 二分查找、 快慢指针、 左右指针、 滑动窗口、 前缀和数组、 差分数组。
这些技巧就好比工具库里各种型号的工具,你得有的选,才能运用出来不是吗?那么对于初学者,工具库里面就没什么东西,拿什么死磕?用锯子去挖石头,这不扯淡呢吗?
那么如何解决技巧储备不足的问题呢?这就是我想解决的问题,我把所有常用的算法技巧都集合起来,给你整理出一份「算法小抄」,就可以帮你在做题的过程中有一个方向性的指导。
下次遇到数组相关的题目时,你把我总结的数组相关的技巧都拿出来,一个个试,形成一套固定的做题方法,那遇到新的算法题,不就来者不惧了吗?
2、对于递归的理解不透彻
递归思维是经典的计算机思维,如果掌握不好,很多时候你去看别人的题解代码可能都看不懂,这就很打击人的自信,觉得自己好菜。
不用气馁,递归确实不好理解,因为它是「计算机思维」嘛,你是个人,又不是个计算机,当然不容易理解了。
要掌握递归,关键要跳出细节,培养框架思维,尝试从整体上理解算法的过程。
以我的刷题经验,初学者最好从「树」相关的问题开始刷题,为此我特意写了 手把手刷二叉树(纲领篇),帮你从二叉树的视角理解各种复杂的算法。
另外, 我的刷题插件 中也集成了 手把手刷题二叉树题目 的功能,帮助大家培养框架思维。
别不信,到后面你会发现递归代码反而是最简单,最容易理解的。
你能在这里学到什么
我的读者可以大致分两类:一类对算法完全没有兴趣,属于面向笔试学习算法的读者;另一类是对算法感兴趣,能够享受纯粹求知乐趣的读者。
我个人属于后者,自然希望后者多一些,但毕竟人各有志,两种读者没有对错之分,而且人总是会变的,说不定学着学着就改变想法了呢?这也未可知。
当然,我的文章能够同时满足这两者的需求:
首先,我会结合自己的刷题经验,有所取舍,忽略性价比不高的算法技巧,抽象出常用算法的框架,帮助大家高效掌握算法,搞定面试笔试。
另外,我也会清晰地描述自己的解题过程,阐述算法的底层原理,帮助大家培养框架思维以及举一反三的能力,力求让大家真正爱上算法,每天不刷两道题都难受的那种。
所以,不管你是刚刚入门算法的小白,还是已经对算法有所小成,希望进阶,我相信这些内容都会对你有帮助。
最后,公众号后台回复「进群」可加入算法群,大家一起刷题,从现在开始,养成刷题的好习惯:
labuladong的更多相关文章
- leetcode股票问题方法收集 转载自微信公众号labuladong
一.穷举框架首先,还是一样的思路:如何穷举?这里的穷举思路和上篇文章递归的思想不太一样. 递归其实是符合我们思考的逻辑的,一步步推进,遇到无法解决的就丢给递归,一不小心就做出来了,可读性还很好.缺点就 ...
- 笔试算法稳了,GitHub 50k Star《labuladong的算法小抄》
秋招算法有救了!!! 前不久在 GitHub 出现了一个手把手带你刷 LeetCode 的项目:fucking-algorithm. 该项目此前在 GitHub 开源后,连续多次霸榜 GitHub T ...
- labuladong 算法小抄
<labuladong的算法小抄官方完整版> 本书目前可以手把手带你解决 110 道 LeetCode 算法问题,而且在不断更 新,全部基于 LeetCode 的题目,涵盖了所有题型和技巧 ...
- labuladong 05.16 微信直播
labuladong 05.16 微信直播 一.基础: 1.校招相关 1)扫盲 秋招:8-10月 提前批:7月 暑期实习:3-5月 非必须 2)关注公司前景,部门信息,公司财报 企查查,天眼查,多获取 ...
- LeetCode practice
子集和问题:给定一组数和一个值,从这组数中选出若干个数使其和为给定的值.这是个NPC问题. 1.https://leetcode.com/problems/counting-bits/#/soluti ...
- eetcode必要技巧--动态规划(一)
首先我们要搞清楚什么是动态规划 动态规划是运筹学中用于求解决策过程中的最优化数学方法.当然,我们在这里关注的是作为一种算法设计技术,作为一种使用多阶段决策过程最优的通用方法. 当然这个很难理解,但是按 ...
- LeetCode(239.滑动窗口的最大值
题目: 给定一个数组nums,有一个大小为k的滑动窗口从数组的最左侧移动到最右侧,你只可以看到滑动窗口内的k个数字.滑动窗口每次只向右移动一位. 返回滑动窗口中的最大值. 示例: 输入: nums = ...
- GitHub 热点速览 Vol.18:刷 LeetCode 的正确姿势
作者:HelloGitHub-小鱼干 摘要:找对路子,事半功倍,正如本周 GitHub Trending #刷 LeetCode# 主题想表达的那般,正确的学习姿势方能让人走得更远,走进大厂
- LeetCode 到底怎么刷?GitHub 上多位大厂程序员亲测的高效刷题方式
作者:HelloGitHub-小鱼干 在众多的诸如阿里.腾讯等大厂之中,最看中面试者刷题技能的大概要数有"链表厂"之称的字节跳动了.作为一个新晋大厂,字节跳动以高薪.技术大佬云集吸 ...
- leetcode刷题记录——树
递归 104.二叉树的最大深度 /** * Definition for a binary tree node. * public class TreeNode { * int val; * Tree ...
随机推荐
- OpenStack云计算平台部署(单节点)
环境配置 虚拟机(centos7 .内存8G.硬盘300G.处理器4核并开启intel vt-x,网络模式设置为NAT,虚拟机网络一定要设置好,并可以ping通baidu,不然有中途掉IP的情况发生) ...
- Linux常用基础命令一
一.目录操作 进入路径 cd [目录地址] 切换回主目录 cd 返回上一个路径 cd - 打印当前路径 pwd 列出目录下文件 ls ---查看只包含非隐藏文件 ls -a -----查看目录下所有文 ...
- JAVA反序列化漏洞修复解决方法
MyObject类建立了Serializable模块,而且重新写过了readObject()变量,仅有建立了Serializable模块的类的目标才能够被实例化,沒有建立此模块的类将无法使他们的任意状 ...
- MySQL8 Group By 新特性
MySQL8 Group By 新特性 此生此夜不长好,明月明年何处看. 一.简介 MySQL8 新特性之 Group By 不再隐式排序.MySQL8对于group by 字段不再隐式排序,如需 ...
- Python工具箱系列(五)
上一期介绍了Anaconda的安装,本期介绍Miniconda的安装,它们共同的部分是Conda,确实如此.Conda是一个开源的包管理系统,本身的志向非常宏大,要为Python. R. Ruby. ...
- 【To B产品怎么做?】泛用户体验
目录 - 什么是泛用户体验? - 如何做好泛用户体验? - 泛用户体验有什么用? *预计阅读时间15分钟 不知道你有没有过这种体验,客服妹子的声音软糯,氛围微妙,用词标准,张口就是:给你带来了不好的体 ...
- 使用nginx反向代理RabbitMQ的web界面
直接贴nginx的conf配置: server { listen 80; server_name www.xxxxx.com; location / { client_body_buffer_size ...
- Elastic:创建你的第一个Elastic alert
文章转载自:https://blog.csdn.net/UbuntuTouch/article/details/105340379 在Elasticsearch可以提供给我们数据的存储及快速的搜索,但 ...
- 使用prometheus + granafa 监控mysql主从
若主从同步数据库未同步默认的mysql表,则也需要在从库上创建mysql用户mysqld_exporter用来收集监控数据 mysqld_exporter安装部署 这里采取的是mysqld_expor ...
- windows系统下使用bat脚本文件设置MySQL系统环境变量
说明:在一个bat文件中设置tomcat环境变量后,不能直接使用,需要另起一个bat文件才能使用 号开头的行不要写在bat文件中 # 这个bat文件实现的功能:设置环境变量 @echo off set ...