- 介绍:本项目是一套完整的刷题计划,旨在帮助大家少走弯路,循序渐进学算法,关注作者
- PDF版本 : 「代码随想录」算法精讲 PDF 版本 。
- 最强八股文::代码随想录知识星球精华PDF
- 刷题顺序 : README已经将刷题顺序排好了,按照顺序一道一道刷就可以。
- 学习社区 : 一起学习打卡/面试技巧/如何选择offer/大厂内推/职场规则/简历修改/技术分享/程序人生。欢迎加入「代码随想录」知识星球 。
- 提交代码:本项目统一使用C++语言进行讲解,但已经有Java、Python、Go、JavaScript等等多语言版本,感谢这里的每一位贡献者,如果你也想贡献代码点亮你的头像,点击这里了解提交代码的方式。
- 转载须知 :以下所有文章皆为我(程序员Carl)的原创。引用本项目文章请注明出处,发现恶意抄袭或搬运,会动用法律武器维护自己的权益。让我们一起维护一个良好的技术创作环境!
《代码随想录》正式出版啦!!录友专属福利,点击下方可以享五折优惠!详细可以点击这里
LeetCode 刷题攻略
刷题攻略的背景
很多刚开始刷题的同学都有一个困惑:面对leetcode上近两千道题目,从何刷起。
大家平时刷题感觉效率低,浪费的时间主要在三点:
- 找题
- 找到了不应该现阶段做的题
- 没有全套的优质题解可以参考
其实我之前在知乎上回答过这个问题,回答内容大概是按照如下类型来刷数组-> 链表-> 哈希表->字符串->栈与队列->树->回溯->贪心->动态规划->图论->高级数据结构,再从简单刷起,做了几个类型题目之后,再慢慢做中等题目、困难题目。
但我能设身处地的感受到:即使有这样一个整体规划,对于一位初学者甚至算法老手寻找合适自己的题目也是很困难,时间成本很高,而且题目还不一定就是经典题目。
对于刷题,我们都是想用最短的时间按照循序渐进的难度顺序把经典题目都做一遍,这样效率才是最高的!
所以我整理了leetcode刷题攻略:一个超级详细的刷题顺序,每道题目都是我精心筛选,都是经典题目高频面试题,大家只要按照这个顺序刷就可以了,你没看错,README已经把题目顺序都排好了,文章顺序就是刷题顺序!挨个刷就可以,不用自己再去题海里选题了!
而且每道题目我都写了的详细题解(图文并茂,难点配有视频),力扣上我的题解都是排在对应题目的首页,质量是有目共睹的。
那么现在我把刷题顺序都整理出来,是为了帮助更多的学习算法的同学少走弯路!
如果你在刷leetcode,强烈建议先按照本攻略刷题顺序来刷,刷完了你会发现对整个知识体系有一个质的飞跃,不用在题海茫然的寻找方向。
如何使用该刷题攻略
电脑端还看不到留言,大家可以在公众号「代码随想录」,左下角有「刷题攻略」,这是手机版刷题攻略,看完就会发现有很多录友(代码随想录的朋友们)在文章下留言打卡,这份刷题顺序和题解已经陪伴了上万录友了,同时也说明文章的质量是经过上万人的考验!
欢迎每一位学习算法的小伙伴加入到这个学习阵营来!
目前已经更新了,数组-> 链表-> 哈希表->字符串->栈与队列->树->回溯->贪心,八个专题了,正在讲解动态规划!
在刷题攻略中,每个专题开始都有理论基础篇,并不像是教科书般的理论介绍,而是从实战中归纳需要的基础知识。每个专题结束都有总结篇,最这个专题的归纳总结。
如果你是算法老手,这篇攻略也是复习的最佳资料,如果把每个系列对应的总结篇,快速过一遍,整个算法知识体系以及各种解法就重现脑海了。
目前「代码随想录」刷题攻略更新了:200多篇文章,精讲了200道经典算法题目,共60w字的详细图解,部分难点题目还搭配了20分钟左右的视频讲解。
这里每一篇题解,都是精品,值得仔细琢磨。
我在题目讲解中统一使用C++,但你会发现下面几乎每篇题解都配有其他语言版本,Java、Python、Go、JavaScript等等,正是这些热心小伙们的贡献的代码,当然我也会严格把控代码质量。
所以也欢迎大家参与进来,完善题解的各个语言版本,拥抱开源,让更多小伙伴们收益。
准备好了么,刷题攻略开始咯,go go go!
前序
-
编程语言
-
项目
-
编程素养
-
工具
-
求职
-
算法性能分析
杂谈
数组
- 数组过于简单,但你该了解这些!
- 数组:每次遇到二分法,都是一看就会,一写就废
- 数组:就移除个元素很难么?
- 数组:有序数组的平方,还有序么?
- 数组:滑动窗口拯救了你
- 数组:这个循环可以转懵很多人!
- 数组:总结篇
链表
- 关于链表,你该了解这些!
- 链表:听说用虚拟头节点会方便很多?
- 链表:一道题目考察了常见的五个操作!
- 链表:听说过两天反转链表又写不出来了?
- 链表:两两交换链表中的节点
- 链表:删除链表的倒数第 N 个结点
- 链表:链表相交
- 链表:环找到了,那入口呢?
- 链表:总结篇!
哈希表
- 关于哈希表,你该了解这些!
- 哈希表:可以拿数组当哈希表来用,但哈希值不要太大
- 哈希表:查找常用字符
- 哈希表:哈希值太大了,还是得用set
- 哈希表:用set来判断快乐数
- 哈希表:map等候多时了
- 哈希表:其实需要哈希的地方都能找到map的身影
- 哈希表:这道题目我做过?
- 哈希表:解决了两数之和,那么能解决三数之和么?
- 双指针法:一样的道理,能解决四数之和
- 哈希表:总结篇!(每逢总结必经典)
字符串
- 字符串:这道题目,使用库函数一行代码搞定
- 字符串:简单的反转还不够!
- 字符串:替换空格
- 字符串:花式反转还不够!
- 字符串:反转个字符串还有这个用处?
- 帮你把KMP算法学个通透
- 字符串:KMP算法还能干这个!
- 字符串:总结篇!
双指针法
双指针法基本都是应用在数组,字符串与链表的题目上
- 数组:就移除个元素很难么?
- 字符串:这道题目,使用库函数一行代码搞定
- 字符串:替换空格
- 字符串:花式反转还不够!
- 链表:听说过两天反转链表又写不出来了?
- 链表:删除链表的倒数第 N 个结点
- 链表:链表相交
- 链表:环找到了,那入口呢?
- 哈希表:解决了两数之和,那么能解决三数之和么?
- 双指针法:一样的道理,能解决四数之和
- 双指针法:总结篇!
栈与队列
- 栈与队列:来看看栈和队列不为人知的一面
- 栈与队列:我用栈来实现队列怎么样?
- 栈与队列:用队列实现栈还有点别扭
- 栈与队列:系统中处处都是栈的应用
- 栈与队列:匹配问题都是栈的强项
- 栈与队列:有没有想过计算机是如何处理表达式的?
- 栈与队列:滑动窗口里求最大值引出一个重要数据结构
- 栈与队列:求前 K 个高频元素和队列有啥关系?
- 栈与队列:总结篇!
二叉树
- 关于二叉树,你该了解这些!
- 二叉树:一入递归深似海,从此offer是路人
- 二叉树:听说递归能做的,栈也能做!
- 二叉树:前中后序迭代方式的写法就不能统一一下么?
- 二叉树:层序遍历登场!
- 二叉树:你真的会翻转二叉树么?
- 本周小结!(二叉树)
- 二叉树:我对称么?
- 二叉树:看看这些树的最大深度
- 二叉树:看看这些树的最小深度
- 二叉树:我有多少个节点?
- 二叉树:我平衡么?
- 二叉树:找我的所有路径?
- 本周总结!二叉树系列二
- 二叉树:以为使用了递归,其实还隐藏着回溯
- 二叉树:做了这么多题目了,我的左叶子之和是多少?
- 二叉树:我的左下角的值是多少?
- 二叉树:路径总和
- 二叉树:构造二叉树登场!
- 二叉树:构造一棵最大的二叉树
- 本周小结!(二叉树系列三)
- 二叉树:合并两个二叉树
- 二叉树:二叉搜索树登场!
- 二叉树:我是不是一棵二叉搜索树
- 二叉树:搜索树的最小绝对差
- 二叉树:我的众数是多少?
- 二叉树:公共祖先问题
- 本周小结!(二叉树系列四)
- 二叉树:搜索树的公共祖先问题
- 二叉树:搜索树中的插入操作
- 二叉树:搜索树中的删除操作
- 二叉树:修剪一棵搜索树
- 二叉树:构造一棵搜索树
- 二叉树:搜索树转成累加树
- 二叉树:总结篇!(需要掌握的二叉树技能都在这里了)
回溯算法
题目分类大纲如下:
- 关于回溯算法,你该了解这些!
- 回溯算法:组合问题
- 回溯算法:组合问题再剪剪枝
- 回溯算法:求组合总和!
- 回溯算法:电话号码的字母组合
- 本周小结!(回溯算法系列一)
- 回溯算法:求组合总和(二)
- 回溯算法:求组合总和(三)
- 回溯算法:分割回文串
- 回溯算法:复原IP地址
- 回溯算法:求子集问题!
- 本周小结!(回溯算法系列二)
- 回溯算法:求子集问题(二)
- 回溯算法:递增子序列
- 回溯算法:排列问题!
- 回溯算法:排列问题(二)
- 本周小结!(回溯算法系列三)
- 回溯算法去重问题的另一种写法
- 回溯算法:重新安排行程
- 回溯算法:N皇后问题
- 回溯算法:解数独
- 一篇总结带你彻底搞透回溯算法!
贪心算法
题目分类大纲如下:
- 关于贪心算法,你该了解这些!
- 贪心算法:分发饼干
- 贪心算法:摆动序列
- 贪心算法:最大子序和
- 本周小结!(贪心算法系列一)
- 贪心算法:买卖股票的最佳时机II
- 贪心算法:跳跃游戏
- 贪心算法:跳跃游戏II
- 贪心算法:K次取反后最大化的数组和
- 本周小结!(贪心算法系列二)
- 贪心算法:加油站
- 贪心算法:分发糖果
- 贪心算法:柠檬水找零
- 贪心算法:根据身高重建队列
- 本周小结!(贪心算法系列三)
- 贪心算法:根据身高重建队列(续集)
- 贪心算法:用最少数量的箭引爆气球
- 贪心算法:无重叠区间
- 贪心算法:划分字母区间
- 贪心算法:合并区间
- 本周小结!(贪心算法系列四)
- 贪心算法:单调递增的数字
- 贪心算法:买卖股票的最佳时机含手续费
- 贪心算法:我要监控二叉树!
- 贪心算法:总结篇!(每逢总结必经典)
动态规划
动态规划专题已经开始啦,来不及解释了,小伙伴们上车别掉队!
- 关于动态规划,你该了解这些!
- 动态规划:斐波那契数
- 动态规划:爬楼梯
- 动态规划:使用最小花费爬楼梯
- 本周小结!(动态规划系列一)
- 动态规划:不同路径
- 动态规划:不同路径还不够,要有障碍!
- 动态规划:整数拆分,你要怎么拆?
- 动态规划:不同的二叉搜索树
- 本周小结!(动态规划系列二)
背包问题系列:
- 动态规划:关于01背包问题,你该了解这些!
- 动态规划:关于01背包问题,你该了解这些!(滚动数组)
- 动态规划:分割等和子集可以用01背包!
- 动态规划:最后一块石头的重量 II
- 本周小结!(动态规划系列三)
- 动态规划:目标和!
- 动态规划:一和零!
- 动态规划:关于完全背包,你该了解这些!
- 动态规划:给你一些零钱,你要怎么凑?
- 本周小结!(动态规划系列四)
- 动态规划:Carl称它为排列总和!
- 动态规划:以前我没得选,现在我选择再爬一次!
- 动态规划: 给我个机会,我再兑换一次零钱
- 动态规划:一样的套路,再求一次完全平方数
- 本周小结!(动态规划系列五)
- 动态规划:单词拆分
- 动态规划:关于多重背包,你该了解这些!
- 听说背包问题很难? 这篇总结篇来拯救你了
打家劫舍系列:
股票系列:
- 动态规划:买卖股票的最佳时机
- 动态规划:本周我们都讲了这些(系列六)
- 动态规划:买卖股票的最佳时机II
- 动态规划:买卖股票的最佳时机III
- 动态规划:买卖股票的最佳时机IV
- 动态规划:最佳买卖股票时机含冷冻期
- 动态规划:本周我们都讲了这些(系列七)
- 动态规划:买卖股票的最佳时机含手续费
- 动态规划:股票系列总结篇
子序列系列:
- 动态规划:最长递增子序列
- 动态规划:最长连续递增序列
- 动态规划:最长重复子数组
- 动态规划:最长公共子序列
- 动态规划:不相交的线
- 动态规划:最大子序和
- 动态规划:判断子序列
- 动态规划:不同的子序列
- 动态规划:两个字符串的删除操作
- 动态规划:编辑距离
- 为了绝杀编辑距离,Carl做了三步铺垫,你都知道么?
- 动态规划:回文子串
- 动态规划:最长回文子序列
- 动态规划总结篇
单调栈
(持续更新中....)
图论
十大排序
数论
高级数据结构经典题目
- 并查集
- 最小生成树
- 线段树
- 树状数组
- 字典树
海量数据处理
补充题目
以上题目是重中之重,大家至少要刷两遍以上才能彻底理解,如果熟练以上题目之后还在找其他题目练手,可以再刷以下题目:
这些题目很不错,但有的题目是和刷题攻略类似的,有的题解后面还会适当补充,所以我还没有将其纳入到刷题攻略。一些题解等日后我完善一下,再纳入到刷题攻略。
数组
- 1365.有多少小于当前数字的数字
- 941.有效的山脉数组 (双指针)
- 1207.独一无二的出现次数 数组在哈希法中的经典应用
- 283.移动零 【数组】【双指针】
- 189.旋转数组
- 724.寻找数组的中心索引
- 34.在排序数组中查找元素的第一个和最后一个位置 (二分法)
- 922.按奇偶排序数组II
- 35.搜索插入位置
链表
- 24.两两交换链表中的节点
- 234.回文链表
- 143.重排链表【数组】【双向队列】【直接操作链表】
- 141.环形链表
- 160.相交链表
哈希表
- 205.同构字符串:【哈希表的应用】
字符串
- 925.长按键入 模拟匹配
- 0844.比较含退格的字符串【栈模拟】【空间更优的双指针】
二叉树
- 129.求根到叶子节点数字之和
- 1382.将二叉搜索树变平衡 构造平衡二叉搜索树
- 100.相同的树 同101.对称二叉树 一个思路
- 116.填充每个节点的下一个右侧节点指针
回溯算法
贪心
- 649.Dota2参议院 有难度
- 1221.分割平衡字符 简单贪心
动态规划
- 5.最长回文子串 和647.回文子串 差不多是一样的
- 132.分割回文串II 与647.回文子串和 5.最长回文子串 很像
- 673.最长递增子序列的个数
图论
并查集
- 684.冗余连接 【并查集基础题目】
- 685.冗余连接II【并查集的应用】
模拟
位运算
算法模板
B站算法视频讲解
以下为B站「代码随想录」算法讲解视频:
- KMP算法(理论篇)
- KMP算法(代码篇)
- 回溯算法理论基础
- 回溯算法之组合问题(力扣题目:77.组合)
- 组合问题的剪枝操作(对应力扣题目:77.组合)
- 组合总和(对应力扣题目:39.组合总和)
- 分割回文串(对应力扣题目:131.分割回文串)
- 二叉树理论基础
- 二叉树的递归遍历
- 二叉树的非递归遍历(一)
(持续更新中....)
贡献者
点此这里查看LeetCode-Master的所有贡献者。感谢他们补充了LeetCode-Master的其他语言版本,让更多的读者收益于此项目。
关于作者
大家好,我是程序员Carl,哈工大师兄,《代码随想录》作者,先后在腾讯和百度从事后端技术研发,CSDN博客专家。对算法和C++后端技术有一定的见解,利用工作之余重新刷leetcode。
加入「代码随想录」刷题小分队(微信群),可以扫下方二维码加我微信。
如果是已工作,备注:姓名-城市-岗位-组队刷题。如果学生,备注:姓名-学校-年级-组队刷题。备注没有自我介绍不通过哦
公众号
更多精彩文章持续更新,微信搜索:「代码随想录」第一时间围观,关注后回复:666,可以获得我的所有算法专题原创PDF。
「代码随想录」每天准时为你推送一篇经典面试题目,帮你梳理算法知识体系,轻松学习算法!,并且公众号里有大量学习资源,也有我自己的学习心得和方法总结,更有上万录友们在这里打卡学习。
来看看就知道了,你会发现相见恨晚!