{"id":13459302,"url":"https://github.com/youngyangyang04/leetcode-master","last_synced_at":"2025-05-12T18:13:11.839Z","repository":{"id":36979481,"uuid":"228016443","full_name":"youngyangyang04/leetcode-master","owner":"youngyangyang04","description":"《代码随想录》LeetCode 刷题攻略：200道经典题目刷题顺序，共60w字的详细图解，视频难点剖析，50余张思维导图，支持C++，Java，Python，Go，JavaScript等多语言版本，从此算法学习不再迷茫！🔥🔥 来看看，你会发现相见恨晚！🚀 ","archived":false,"fork":false,"pushed_at":"2025-04-09T11:59:27.000Z","size":99643,"stargazers_count":55666,"open_issues_count":224,"forks_count":11963,"subscribers_count":385,"default_branch":"master","last_synced_at":"2025-04-23T17:00:48.688Z","etag":null,"topics":["algorithm","cpp","go","interview","java","javascript","leetcode","offer","programmer","python"],"latest_commit_sha":null,"homepage":"","language":"Shell","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/youngyangyang04.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2019-12-14T12:05:42.000Z","updated_at":"2025-04-23T15:28:17.000Z","dependencies_parsed_at":"2024-03-18T03:23:19.099Z","dependency_job_id":"faf08e13-6e6f-4b11-8234-3f56571a2c47","html_url":"https://github.com/youngyangyang04/leetcode-master","commit_stats":{"total_commits":5156,"total_committers":758,"mean_commits":6.802110817941952,"dds":0.8035298681148177,"last_synced_commit":"0d48886c2082d7f3a6bfd7db1c7421b18594190a"},"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/youngyangyang04%2Fleetcode-master","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/youngyangyang04%2Fleetcode-master/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/youngyangyang04%2Fleetcode-master/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/youngyangyang04%2Fleetcode-master/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/youngyangyang04","download_url":"https://codeload.github.com/youngyangyang04/leetcode-master/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":252522743,"owners_count":21761787,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["algorithm","cpp","go","interview","java","javascript","leetcode","offer","programmer","python"],"created_at":"2024-07-31T09:01:15.004Z","updated_at":"2025-05-05T15:24:28.923Z","avatar_url":"https://github.com/youngyangyang04.png","language":"Shell","readme":"\n👉 推荐 [在线阅读](http://programmercarl.com/) (Github在国内访问经常不稳定)         \n👉 推荐 [Gitee同步](https://gitee.com/programmercarl/leetcode-master) \n\n\u003e 1. **介绍** ：本项目是一套完整的刷题计划，旨在帮助大家少走弯路，循序渐进学算法，[关注作者](#关于作者)\n\u003e 2. **正式出版** ：[《代码随想录》](https://programmercarl.com/qita/publish.html) 。\n\u003e 3. **PDF版本** ：[「代码随想录」算法精讲 PDF 版本](https://programmercarl.com/qita/algo_pdf.html) 。\n\u003e 4. **算法公开课** ：[《代码随想录》算法视频公开课](https://www.bilibili.com/video/BV1fA4y1o715) 。\n\u003e 5. **最强八股文** ：[代码随想录知识星球精华PDF](https://www.programmercarl.com/other/kstar_baguwen.html) 。\n\u003e 6. **刷题顺序** ：README已经将刷题顺序排好了，按照顺序一道一道刷就可以。\n\u003e 7. **学习社区** ：一起学习打卡/面试技巧/如何选择offer/大厂内推/职场规则/简历修改/技术分享/程序人生。欢迎加入[「代码随想录」知识星球](https://programmercarl.com/other/kstar.html) 。\n\u003e 8. **提交代码** ：本项目统一使用C++语言进行讲解，但已经有Java、Python、Go、JavaScript等等多语言版本，感谢[这里的每一位贡献者](https://github.com/youngyangyang04/leetcode-master/graphs/contributors)，如果你也想贡献代码点亮你的头像，[点击这里](https://www.programmercarl.com/qita/join.html)了解提交代码的方式。\n\u003e 9. **转载须知** ：以下所有文章皆为我（[程序员Carl](https://github.com/youngyangyang04)）的原创。引用本项目文章请注明出处，发现恶意抄袭或搬运，会动用法律武器维护自己的权益。让我们一起维护一个良好的技术创作环境！\n\n\n\u003cp align=\"center\"\u003e\n\u003ca href=\"https://programmercarl.com/xunlian/xunlianying.html\" target=\"_blank\"\u003e\n\t\u003cimg src=\"./pics/训练营.png\" width=\"800\"/\u003e\n\u003c/a\u003e\n\u003c/p\u003e\n\n# LeetCode 刷题攻略\n\n## 刷题攻略的背景\n\n很多刚开始刷题的同学都有一个困惑：面对leetcode上近两千道题目，从何刷起。\n\n大家平时刷题感觉效率低，浪费的时间主要在三点：\n\n* 找题\n* 找到了不应该现阶段做的题\n* 没有全套的优质题解可以参考\n\n其实我之前在知乎上回答过这个问题，回答内容大概是按照如下类型来刷数组-\u003e 链表-\u003e 哈希表-\u003e字符串-\u003e栈与队列-\u003e树-\u003e回溯-\u003e贪心-\u003e动态规划-\u003e图论-\u003e高级数据结构，再从简单刷起，做了几个类型题目之后，再慢慢做中等题目、困难题目。\n\n但我能设身处地的感受到：即使有这样一个整体规划，对于一位初学者甚至算法老手寻找合适自己的题目也是很困难，时间成本很高，而且题目还不一定就是经典题目。\n\n对于刷题，我们都是想用最短的时间**按照循序渐进的难度顺序把经典题目都做一遍**，这样效率才是最高的！\n\n所以我整理了leetcode刷题攻略：一个超级详细的刷题顺序，**每道题目都是我精心筛选，都是经典题目高频面试题**，大家只要按照这个顺序刷就可以了，**你没看错，README已经把题目顺序都排好了，文章顺序就是刷题顺序！挨个刷就可以，不用自己再去题海里选题了！**\n\n而且每道题目我都写了的详细题解（图文并茂，难点配有视频），力扣上我的题解都是排在对应题目的首页，质量是有目共睹的。\n\n**那么现在我把刷题顺序都整理出来，是为了帮助更多的学习算法的同学少走弯路！**\n\n如果你在刷leetcode，强烈建议先按照本攻略刷题顺序来刷，刷完了你会发现对整个知识体系有一个质的飞跃，不用在题海茫然的寻找方向。\n\n\u003cdiv align=\"center\"\u003e\u003cstrong\u003e最新文章会首发在公众号「代码随想录」，扫码看看吧，你会发现相见恨晚！\u003c/strong\u003e\u003c/img\u003e\u003c/div\u003e\n\n\u003cdiv align=\"center\"\u003e\u003cimg src='./pics/公众号二维码.jpg' width=150 alt=''\u003e \u003c/img\u003e\u003c/div\u003e \n\n## 如何使用该刷题攻略\n\n按照先面的排列顺序，从数组开始刷起就可以了，顺序都安排好了，按顺序刷就好。\n\n在刷题攻略中，每个专题开始都有理论基础篇，并不像是教科书般的理论介绍，而是从实战中归纳需要的基础知识。每个专题结束都有总结篇，最这个专题的归纳总结。\n\n如果你是算法老手，这篇攻略也是复习的最佳资料，如果把每个系列对应的总结篇，快速过一遍，整个算法知识体系以及各种解法就重现脑海了。\n\n**这里每一篇题解，都是精品，值得仔细琢磨**。\n\n我在题目讲解中统一使用C++，但你会发现下面几乎每篇题解都配有其他语言版本，Java、Python、Go、JavaScript等等，正是这些[热心小伙们](https://github.com/youngyangyang04/leetcode-master/graphs/contributors)贡献的代码，当然我也会严格把控代码质量。 \n\n**所以也欢迎大家参与进来，完善题解的各个语言版本，拥抱开源，让更多小伙伴们受益**。\n\n准备好了么，刷题攻略开始咯，go go go！\n\n---------------------------------------------\n\n## 前序\n\n* [做项目（多个C++、Java、Go、前端、测开项目）](https://programmercarl.com/other/kstar.html)\n\n\n* 编程语言\n    * [C++面试\u0026C++学习指南知识点整理](https://github.com/youngyangyang04/TechCPP)\n    * [编程语言基础课](https://kamacoder.com/courseshop.php)\n    * [23种设计模式](https://github.com/youngyangyang04/kama-DesignPattern)\n    * [大厂算法笔试题](https://kamacoder.com/company.php)\n\n* 工具 \n    * [一站式vim配置](https://github.com/youngyangyang04/PowerVim)\n    * [保姆级Git入门教程，万字详解](https://mp.weixin.qq.com/s/Q_O0ey4C9tryPZaZeJocbA)\n    * [程序员应该用什么用具来写文档？](./problems/前序/程序员写文档工具.md)\n\n* 求职 \n    * [ACM模式练习网站，卡码网](https://kamacoder.com/)\n    * [程序员的简历应该这么写！！（附简历模板）](./problems/前序/程序员简历.md)\n    * [【专业技能】应该这样写！](https://programmercarl.com/other/jianlizhuanye.html)\n    * [【项目经历】应该这样写！](https://programmercarl.com/other/jianlixiangmu.html)\n    * [BAT级别技术面试流程和注意事项都在这里了](./problems/前序/BAT级别技术面试流程和注意事项都在这里了.md)\n    \n* 算法性能分析\n    * [关于时间复杂度，你不知道的都在这里！](./problems/前序/时间复杂度.md)\n    * [O(n)的算法居然超时了，此时的n究竟是多大？](./problems/前序/算法超时.md)\n    * [通过一道面试题目，讲一讲递归算法的时间复杂度！](./problems/前序/递归算法的时间复杂度.md)\n    * [关于空间复杂度，可能有几个疑问？](./problems/前序/空间复杂度.md)\n    * [递归算法的时间与空间复杂度分析！](./problems/前序/递归算法的时间与空间复杂度分析.md)\n    * [刷了这么多题，你了解自己代码的内存消耗么？](./problems/前序/内存消耗.md)\n\n\n## 数组 \n\n1. [数组过于简单，但你该了解这些！](./problems/数组理论基础.md) \n2. [数组：704.二分查找](./problems/0704.二分查找.md)\n3. [数组：27.移除元素](./problems/0027.移除元素.md)\n4. [数组：977.有序数组的平方](./problems/0977.有序数组的平方.md)    \n5. [数组：209.长度最小的子数组](./problems/0209.长度最小的子数组.md)\n6. [数组：区间和](./problems/kamacoder/0058.区间和.md)\n7. [数组：开发商购买土地](./problems/kamacoder/0044.开发商购买土地.md)\n8. [数组：59.螺旋矩阵II](./problems/0059.螺旋矩阵II.md)\n9. [数组：总结篇](./problems/数组总结篇.md)\n\n## 链表\n\n1. [关于链表，你该了解这些！](./problems/链表理论基础.md)\n2. [链表：203.移除链表元素](./problems/0203.移除链表元素.md)\n3. [链表：707.设计链表](./problems/0707.设计链表.md)\n4. [链表：206.翻转链表](./problems/0206.翻转链表.md) \n5. [链表：24.两两交换链表中的节点](./problems/0024.两两交换链表中的节点.md)\n6. [链表：19.删除链表的倒数第 N 个结点](./problems/0019.删除链表的倒数第N个节点.md)\n7. [链表：链表相交](./problems/面试题02.07.链表相交.md)\n8. [链表：142.环形链表](./problems/0142.环形链表II.md)\n9. [链表：总结篇！](./problems/链表总结篇.md)\n\n## 哈希表\n\n1. [关于哈希表，你该了解这些！](./problems/哈希表理论基础.md)\n2. [哈希表：242.有效的字母异位词](./problems/0242.有效的字母异位词.md)\n3. [哈希表：1002.查找常用字符](./problems/1002.查找常用字符.md)\n4. [哈希表：349.两个数组的交集](./problems/0349.两个数组的交集.md)\n5. [哈希表：202.快乐数](./problems/0202.快乐数.md)\n6. [哈希表：1.两数之和](./problems/0001.两数之和.md)\n7. [哈希表：454.四数相加II](./problems/0454.四数相加II.md)\n8. [哈希表：383.赎金信](./problems/0383.赎金信.md)\n9. [哈希表：15.三数之和](./problems/0015.三数之和.md)\n10. [双指针法：18.四数之和](./problems/0018.四数之和.md)\n11. [哈希表：总结篇！](./problems/哈希表总结.md)\n\n\n## 字符串\n\n1. [字符串：344.反转字符串](./problems/0344.反转字符串.md)\n2. [字符串：541.反转字符串II](./problems/0541.反转字符串II.md)\n3. [字符串：替换数字](./problems/kamacoder/0054.替换数字.md)\n4. [字符串：151.翻转字符串里的单词](./problems/0151.翻转字符串里的单词.md)\n5. [字符串：右旋字符串](./problems/kamacoder/0055.右旋字符串.md)\n6. [帮你把KMP算法学个通透](./problems/0028.实现strStr.md)\n8. [字符串：459.重复的子字符串](./problems/0459.重复的子字符串.md)\n9. [字符串：总结篇！](./problems/字符串总结.md)\n\n## 双指针法 \n\n双指针法基本都是应用在数组，字符串与链表的题目上\n\n1. [数组：27.移除元素](./problems/0027.移除元素.md)\n2. [字符串：344.反转字符串](./problems/0344.反转字符串.md)\n3. [字符串：替换数字](./problems/kamacoder/0054.替换数字.md)\n4. [字符串：151.翻转字符串里的单词](./problems/0151.翻转字符串里的单词.md)\n5. [链表：206.翻转链表](./problems/0206.翻转链表.md)\n6. [链表：19.删除链表的倒数第 N 个结点](./problems/0019.删除链表的倒数第N个节点.md)\n7. [链表：链表相交](./problems/面试题02.07.链表相交.md)\n8. [链表：142.环形链表](./problems/0142.环形链表II.md)\n9. [双指针：15.三数之和](./problems/0015.三数之和.md)\n10. [双指针：18.四数之和](./problems/0018.四数之和.md)\n11. [双指针：总结篇！](./problems/双指针总结.md)\n\n## 栈与队列\n\n1. [栈与队列：理论基础](./problems/栈与队列理论基础.md)\n2. [栈与队列：232.用栈实现队列](./problems/0232.用栈实现队列.md)\n3. [栈与队列：225.用队列实现栈](./problems/0225.用队列实现栈.md)\n4. [栈与队列：20.有效的括号](./problems/0020.有效的括号.md)\n5. [栈与队列：1047.删除字符串中的所有相邻重复项](./problems/1047.删除字符串中的所有相邻重复项.md)\n6. [栈与队列：150.逆波兰表达式求值](./problems/0150.逆波兰表达式求值.md)\n7. [栈与队列：239.滑动窗口最大值](./problems/0239.滑动窗口最大值.md)\n8. [栈与队列：347.前K个高频元素](./problems/0347.前K个高频元素.md)\n9. [栈与队列：总结篇！](./problems/栈与队列总结.md)\n\n## 二叉树 \n\n\n题目分类大纲如下：           \n\u003cimg src='https://file.kamacoder.com/pics/20240424172231.png' width=600 alt='二叉树大纲'\u003e \u003c/img\u003e\u003c/div\u003e\n\n1. [关于二叉树，你该了解这些！](./problems/二叉树理论基础.md)\n2. [二叉树：二叉树的递归遍历](./problems/二叉树的递归遍历.md)\n3. [二叉树：二叉树的迭代遍历](./problems/二叉树的迭代遍历.md)\n4. [二叉树：二叉树的统一迭代法](./problems/二叉树的统一迭代法.md)\n5. [二叉树：二叉树的层序遍历](./problems/0102.二叉树的层序遍历.md) \n6. [二叉树：226.翻转二叉树](./problems/0226.翻转二叉树.md) \n7. [本周小结！（二叉树）](./problems/周总结/20200927二叉树周末总结.md)\n8. [二叉树：101.对称二叉树](./problems/0101.对称二叉树.md)\n9. [二叉树：104.二叉树的最大深度](./problems/0104.二叉树的最大深度.md)\n10. [二叉树：111.二叉树的最小深度](./problems/0111.二叉树的最小深度.md)\n11. [二叉树：222.完全二叉树的节点个数](./problems/0222.完全二叉树的节点个数.md)\n12. [二叉树：110.平衡二叉树](./problems/0110.平衡二叉树.md)\n13. [二叉树：257.二叉树的所有路径](./problems/0257.二叉树的所有路径.md)\n14. [本周总结！（二叉树）](./problems/周总结/20201003二叉树周末总结.md)\n16. [二叉树：404.左叶子之和](./problems/0404.左叶子之和.md)\n17. [二叉树：513.找树左下角的值](./problems/0513.找树左下角的值.md)\n18. [二叉树：112.路径总和](./problems/0112.路径总和.md)\n19. [二叉树：106.构造二叉树](./problems/0106.从中序与后序遍历序列构造二叉树.md)\n20. [二叉树：654.最大二叉树](./problems/0654.最大二叉树.md)\n21. [本周小结！（二叉树）](./problems/周总结/20201010二叉树周末总结.md) \n22. [二叉树：617.合并两个二叉树](./problems/0617.合并二叉树.md)\n23. [二叉树：700.二叉搜索树登场！](./problems/0700.二叉搜索树中的搜索.md)\n24. [二叉树：98.验证二叉搜索树](./problems/0098.验证二叉搜索树.md)\n25. [二叉树：530.搜索树的最小绝对差](./problems/0530.二叉搜索树的最小绝对差.md)\n26. [二叉树：501.二叉搜索树中的众数](./problems/0501.二叉搜索树中的众数.md)\n27. [二叉树：236.公共祖先问题](./problems/0236.二叉树的最近公共祖先.md)\n28. [本周小结！（二叉树）](./problems/周总结/20201017二叉树周末总结.md)\n29. [二叉树：235.搜索树的最近公共祖先](./problems/0235.二叉搜索树的最近公共祖先.md)\n30. [二叉树：701.搜索树中的插入操作](./problems/0701.二叉搜索树中的插入操作.md)\n31. [二叉树：450.搜索树中的删除操作](./problems/0450.删除二叉搜索树中的节点.md)\n32. [二叉树：669.修剪二叉搜索树](./problems/0669.修剪二叉搜索树.md)\n33. [二叉树：108.将有序数组转换为二叉搜索树](./problems/0108.将有序数组转换为二叉搜索树.md)\n34. [二叉树：538.把二叉搜索树转换为累加树](./problems/0538.把二叉搜索树转换为累加树.md)\n35. [二叉树：总结篇！（需要掌握的二叉树技能都在这里了）](./problems/二叉树总结篇.md)\n\n## 回溯算法 \n\n题目分类大纲如下：             \n\n\u003cimg src='https://file.kamacoder.com/pics/20240424172311.png' width=600 alt='回溯算法大纲'\u003e \u003c/img\u003e\u003c/div\u003e\n\n1. [关于回溯算法，你该了解这些！](./problems/回溯算法理论基础.md)\n2. [回溯算法：77.组合](./problems/0077.组合.md)\n3. [回溯算法：77.组合优化](./problems/0077.组合优化.md)\n4. [回溯算法：216.组合总和III](./problems/0216.组合总和III.md)\n5. [回溯算法：17.电话号码的字母组合](./problems/0017.电话号码的字母组合.md)\n6. [本周小结！（回溯算法系列一）](./problems/周总结/20201030回溯周末总结.md)\n7. [回溯算法：39.组合总和](./problems/0039.组合总和.md)\n8. [回溯算法：40.组合总和II](./problems/0040.组合总和II.md)\n9. [回溯算法：131.分割回文串](./problems/0131.分割回文串.md)\n10. [回溯算法：93.复原IP地址](./problems/0093.复原IP地址.md)\n11. [回溯算法：78.子集](./problems/0078.子集.md)\n12. [本周小结！（回溯算法系列二）](./problems/周总结/20201107回溯周末总结.md)\n13. [回溯算法：90.子集II](./problems/0090.子集II.md)\n14. [回溯算法：491.递增子序列](./problems/0491.递增子序列.md)\n15. [回溯算法：46.全排列](./problems/0046.全排列.md)\n16. [回溯算法：47.全排列II](./problems/0047.全排列II.md)\n17. [本周小结！（回溯算法系列三）](./problems/周总结/20201112回溯周末总结.md)\n18. [回溯算法去重问题的另一种写法](./problems/回溯算法去重问题的另一种写法.md)\n19. [回溯算法：332.重新安排行程](./problems/0332.重新安排行程.md)\n20. [回溯算法：51.N皇后](./problems/0051.N皇后.md)\n21. [回溯算法：37.解数独](./problems/0037.解数独.md)\n22. [回溯算法总结篇](./problems/回溯总结.md)\n\n## 贪心算法 \n\n题目分类大纲如下：             \n\n\n\u003cimg src='https://file.kamacoder.com/pics/20210917104315.png' width=600 alt='贪心算法大纲'\u003e \u003c/img\u003e\u003c/div\u003e\n\n1. [关于贪心算法，你该了解这些！](./problems/贪心算法理论基础.md)\n2. [贪心算法：455.分发饼干](./problems/0455.分发饼干.md)\n3. [贪心算法：376.摆动序列](./problems/0376.摆动序列.md)\n4. [贪心算法：53.最大子序和](./problems/0053.最大子序和.md)\n5. [本周小结！（贪心算法系列一）](./problems/周总结/20201126贪心周末总结.md)\n6. [贪心算法：122.买卖股票的最佳时机II](./problems/0122.买卖股票的最佳时机II.md)\n7. [贪心算法：55.跳跃游戏](./problems/0055.跳跃游戏.md)\n8. [贪心算法：45.跳跃游戏II](./problems/0045.跳跃游戏II.md)\n9. [贪心算法：1005.K次取反后最大化的数组和](./problems/1005.K次取反后最大化的数组和.md)\n10. [本周小结！（贪心算法系列二）](./problems/周总结/20201203贪心周末总结.md)\n11. [贪心算法：134.加油站](./problems/0134.加油站.md)\n12. [贪心算法：135.分发糖果](./problems/0135.分发糖果.md)\n13. [贪心算法：860.柠檬水找零](./problems/0860.柠檬水找零.md)\n14. [贪心算法：406.根据身高重建队列](./problems/0406.根据身高重建队列.md)\n15. [本周小结！（贪心算法系列三）](./problems/周总结/20201217贪心周末总结.md)\n16. [贪心算法：406.根据身高重建队列（续集）](./problems/根据身高重建队列（vector原理讲解）.md)\n17. [贪心算法：452.用最少数量的箭引爆气球](./problems/0452.用最少数量的箭引爆气球.md)\n18. [贪心算法：435.无重叠区间](./problems/0435.无重叠区间.md)\n19. [贪心算法：763.划分字母区间](./problems/0763.划分字母区间.md)\n20. [贪心算法：56.合并区间](./problems/0056.合并区间.md)\n21. [本周小结！（贪心算法系列四）](./problems/周总结/20201224贪心周末总结.md)\n22. [贪心算法：738.单调递增的数字](./problems/0738.单调递增的数字.md)\n23. [贪心算法：968.监控二叉树](./problems/0968.监控二叉树.md)\n24. [贪心算法：总结篇！（每逢总结必经典）](./problems/贪心算法总结篇.md)\n\n## 动态规划\n\n动态规划专题已经开始啦，来不及解释了，小伙伴们上车别掉队！\n\n\u003cimg src='https://code-thinking.cdn.bcebos.com/pics/动态规划-总结大纲1.jpg' width=500\u003e \u003c/img\u003e\u003c/div\u003e\n1. [关于动态规划，你该了解这些！](./problems/动态规划理论基础.md)\n2. [动态规划：509.斐波那契数](./problems/0509.斐波那契数.md)\n3. [动态规划：70.爬楼梯](./problems/0070.爬楼梯.md)\n4. [动态规划：746.使用最小花费爬楼梯](./problems/0746.使用最小花费爬楼梯.md)\n5. [本周小结！（动态规划系列一）](./problems/周总结/20210107动规周末总结.md)\n6. [动态规划：62.不同路径](./problems/0062.不同路径.md)\n7. [动态规划：63.不同路径II](./problems/0063.不同路径II.md)\n8. [动态规划：343.整数拆分](./problems/0343.整数拆分.md)\n9. [动态规划：96.不同的二叉搜索树](./problems/0096.不同的二叉搜索树.md)\n10. [本周小结！（动态规划系列二）](./problems/周总结/20210114动规周末总结.md)\n\n背包问题系列：\n\n\u003cimg src='https://code-thinking.cdn.bcebos.com/pics/动态规划-背包问题总结.png' width=500 alt='背包问题大纲'\u003e \u003c/img\u003e\u003c/div\u003e\n\n\n11. [动态规划：01背包理论基础（二维dp数组）](./problems/背包理论基础01背包-1.md)\n12. [动态规划：01背包理论基础（一维dp数组）](./problems/背包理论基础01背包-2.md)\n13. [动态规划：416.分割等和子集](./problems/0416.分割等和子集.md)\n14. [动态规划：1049.最后一块石头的重量II](./problems/1049.最后一块石头的重量II.md)\n15. [本周小结！（动态规划系列三）](./problems/周总结/20210121动规周末总结.md)\n16. [动态规划：494.目标和](./problems/0494.目标和.md)\n17. [动态规划：474.一和零](./problems/0474.一和零.md) \n18. [动态规划：完全背包理论基础（二维dp数组）](./problems/背包问题理论基础完全背包.md)\n19. [动态规划：完全背包理论基础（一维dp数组）](./problems/背包问题完全背包一维.md)\n20. [动态规划：518.零钱兑换II](./problems/0518.零钱兑换II.md)\n21. [本周小结！（动态规划系列四）](./problems/周总结/20210128动规周末总结.md)\n22. [动态规划：377.组合总和Ⅳ](./problems/0377.组合总和Ⅳ.md)\n23. [动态规划：70.爬楼梯（完全背包版本）](./problems/0070.爬楼梯完全背包版本.md)\n24. [动态规划：322.零钱兑换](./problems/0322.零钱兑换.md)\n25. [动态规划：279.完全平方数](./problems/0279.完全平方数.md)\n26. [本周小结！（动态规划系列五）](./problems/周总结/20210204动规周末总结.md)\n27. [动态规划：139.单词拆分](./problems/0139.单词拆分.md)\n28. [动态规划：多重背包理论基础](./problems/背包问题理论基础多重背包.md)\n29. [背包问题总结篇](./problems/背包总结篇.md)\n\n打家劫舍系列：\n\n29. [动态规划：198.打家劫舍](./problems/0198.打家劫舍.md)\n30. [动态规划：213.打家劫舍II](./problems/0213.打家劫舍II.md)\n31. [动态规划：337.打家劫舍III](./problems/0337.打家劫舍III.md)\n\n股票系列：\n\n\u003cimg src='https://code-thinking.cdn.bcebos.com/pics/股票问题总结.jpg' width=500 alt='股票问题总结'\u003e \u003c/img\u003e\u003c/div\u003e\n\n\n32. [动态规划：121.买卖股票的最佳时机](./problems/0121.买卖股票的最佳时机.md)\n33. [动态规划：本周小结（系列六）](./problems/周总结/20210225动规周末总结.md)\n34. [动态规划：122.买卖股票的最佳时机II](./problems/0122.买卖股票的最佳时机II（动态规划）.md)\n35. [动态规划：123.买卖股票的最佳时机III](./problems/0123.买卖股票的最佳时机III.md)\n36. [动态规划：188.买卖股票的最佳时机IV](./problems/0188.买卖股票的最佳时机IV.md)\n37. [动态规划：309.最佳买卖股票时机含冷冻期](./problems/0309.最佳买卖股票时机含冷冻期.md)\n38. [动态规划：本周小结（系列七）](./problems/周总结/20210304动规周末总结.md)\n39. [动态规划：714.买卖股票的最佳时机含手续费](./problems/0714.买卖股票的最佳时机含手续费（动态规划）.md)\n40. [动态规划：股票系列总结篇](./problems/动态规划-股票问题总结篇.md)\n\n子序列系列： \n\n\u003cimg src='https://code-thinking.cdn.bcebos.com/pics/动态规划-子序列问题总结.jpg' width=500 alt=''\u003e \u003c/img\u003e\u003c/div\u003e\n\n\n41. [动态规划：300.最长递增子序列](./problems/0300.最长上升子序列.md)\n42. [动态规划：674.最长连续递增序列](./problems/0674.最长连续递增序列.md)\n43. [动态规划：718.最长重复子数组](./problems/0718.最长重复子数组.md)\n44. [动态规划：1143.最长公共子序列](./problems/1143.最长公共子序列.md)\n45. [动态规划：1035.不相交的线](./problems/1035.不相交的线.md)\n46. [动态规划：53.最大子序和](./problems/0053.最大子序和（动态规划）.md)\n47. [动态规划：392.判断子序列](./problems/0392.判断子序列.md)\n48. [动态规划：115.不同的子序列](./problems/0115.不同的子序列.md)\n49. [动态规划：583.两个字符串的删除操作](./problems/0583.两个字符串的删除操作.md)\n50. [动态规划：72.编辑距离](./problems/0072.编辑距离.md)\n51. [编辑距离总结篇](./problems/为了绝杀编辑距离，卡尔做了三步铺垫.md)\n52. [动态规划：647.回文子串](./problems/0647.回文子串.md)\n53. [动态规划：516.最长回文子序列](./problems/0516.最长回文子序列.md)\n54. [动态规划总结篇](./problems/动态规划总结篇.md)\n\n\n## 单调栈 \n\n1. [单调栈：739.每日温度](./problems/0739.每日温度.md)\n2. [单调栈：496.下一个更大元素I](./problems/0496.下一个更大元素I.md)\n3. [单调栈：503.下一个更大元素II](./problems/0503.下一个更大元素II.md)\n4. [单调栈：42.接雨水](./problems/0042.接雨水.md)\n5. [单调栈：84.柱状图中最大的矩形](./problems/0084.柱状图中最大的矩形.md)\n\n\n## 图论 \n\n**[图论正式发布](./problems/qita/tulunfabu.md)**\n\n1. [图论：理论基础](./problems/kamacoder/图论理论基础.md)\n2. [图论：深度优先搜索理论基础](./problems/kamacoder/图论深搜理论基础.md)\n3. [图论：所有可达路径](./problems/kamacoder/0098.所有可达路径.md)\n4. [图论：广度优先搜索理论基础](./problems/kamacoder/图论广搜理论基础.md)\n5. [图论：岛屿数量.深搜版](./problems/kamacoder/0099.岛屿的数量深搜.md)\n6. [图论：岛屿数量.广搜版](./problems/kamacoder/0099.岛屿的数量广搜.md)\n7. [图论：岛屿的最大面积](./problems/kamacoder/0100.岛屿的最大面积.md)\n8. [图论：孤岛的总面积](./problems/kamacoder/0101.孤岛的总面积.md)\n9. [图论：沉没孤岛](./problems/kamacoder/0102.沉没孤岛.md)\n10. [图论：水流问题](./problems/kamacoder/0103.水流问题.md)\n11. [图论：建造最大岛屿](./problems/kamacoder/0104.建造最大岛屿.md)\n12. [图论：岛屿的周长](./problems/kamacoder/0106.岛屿的周长.md)\n13. [图论：字符串接龙](./problems/kamacoder/0110.字符串接龙.md)\n14. [图论：有向图的完全可达性](./problems/kamacoder/0105.有向图的完全可达性.md)\n15. [图论：并查集理论基础](./problems/kamacoder/图论并查集理论基础.md)\n16. [图论：寻找存在的路径](./problems/kamacoder/0107.寻找存在的路径.md)\n17. [图论：冗余连接](./problems/kamacoder/0108.冗余连接.md)\n18. [图论：冗余连接II](./problems/kamacoder/0109.冗余连接II.md)\n19. [图论：最小生成树之prim](./problems/kamacoder/0053.寻宝-prim.md)\n20. [图论：最小生成树之kruskal](./problems/kamacoder/0053.寻宝-Kruskal.md)\n21. [图论：拓扑排序](./problems/kamacoder/0117.软件构建.md)\n22. [图论：dijkstra（朴素版）](./problems/kamacoder/0047.参会dijkstra朴素.md)\n23. [图论：dijkstra（堆优化版）](./problems/kamacoder/0047.参会dijkstra堆.md)\n24. [图论：Bellman_ford 算法](./problems/kamacoder/0094.城市间货物运输I.md)\n25. [图论：Bellman_ford 队列优化算法（又名SPFA）](./problems/kamacoder/0094.城市间货物运输I-SPFA.md)\n26. [图论：Bellman_ford之判断负权回路](./problems/kamacoder/0095.城市间货物运输II.md)\n27. [图论：Bellman_ford之单源有限最短路](./problems/kamacoder/0096.城市间货物运输III.md)\n28. [图论：Floyd 算法](./problems/kamacoder/0097.小明逛公园.md)\n29. [图论：A * 算法](./problems/kamacoder/0126.骑士的攻击astar.md)\n30. [图论：最短路算法总结篇](./problems/kamacoder/最短路问题总结篇.md)\n31. [图论：图论总结篇](./problems/kamacoder/图论总结篇.md)\n\n\n（持续更新中....）\n\n# 补充题目\n\n以上题目是重中之重，大家至少要刷两遍以上才能彻底理解，如果熟练以上题目之后还在找其他题目练手，可以再刷以下题目：\n\n这些题目很不错，但有的题目是和刷题攻略类似的，有的题解后面还会适当补充，所以我还没有将其纳入到刷题攻略。一些题解等日后我完善一下，再纳入到刷题攻略。\n\n\n## 数组\n\n* [1365.有多少小于当前数字的数字](./problems/1365.有多少小于当前数字的数字.md)\n* [941.有效的山脉数组](./problems/0941.有效的山脉数组.md)  （双指针）\n* [1207.独一无二的出现次数](./problems/1207.独一无二的出现次数.md) 数组在哈希法中的经典应用\n* [283.移动零](./problems/0283.移动零.md) 【数组】【双指针】\n* [189.旋转数组](./problems/0189.旋转数组.md)\n* [724.寻找数组的中心索引](./problems/0724.寻找数组的中心索引.md)\n* [34.在排序数组中查找元素的第一个和最后一个位置](./problems/0034.在排序数组中查找元素的第一个和最后一个位置.md) （二分法）\n* [922.按奇偶排序数组II](./problems/0922.按奇偶排序数组II.md) \n* [35.搜索插入位置](./problems/0035.搜索插入位置.md)\n\n## 链表\n\n* [24.两两交换链表中的节点](./problems/0024.两两交换链表中的节点.md)\n* [234.回文链表](./problems/0234.回文链表.md)\n* [143.重排链表](./problems/0143.重排链表.md)【数组】【双向队列】【直接操作链表】\n* [141.环形链表](./problems/0141.环形链表.md)\n* [160.相交链表](./problems/面试题02.07.链表相交.md)\n\n## 哈希表\n* [205.同构字符串](./problems/0205.同构字符串.md):【哈希表的应用】\n\n## 字符串\n* [925.长按键入](./problems/0925.长按键入.md) 模拟匹配\n* [0844.比较含退格的字符串](./problems/0844.比较含退格的字符串.md)【栈模拟】【空间更优的双指针】\n\n## 二叉树\n* [129.求根到叶子节点数字之和](./problems/0129.求根到叶子节点数字之和.md)\n* [1382.将二叉搜索树变平衡](./problems/1382.将二叉搜索树变平衡.md) 构造平衡二叉搜索树\n* [100.相同的树](./problems/0100.相同的树.md) 同101.对称二叉树 一个思路\n* [116.填充每个节点的下一个右侧节点指针](./problems/0116.填充每个节点的下一个右侧节点指针.md)\n\n## 回溯算法 \n\n* [52.N皇后II](./problems/0052.N皇后II.md)\n  \n\n## 贪心\n* [649.Dota2参议院](./problems/0649.Dota2参议院.md) 有难度\n* [1221.分割平衡字符](./problems/1221.分割平衡字符串.md) 简单贪心\n\n## 动态规划 \n* [5.最长回文子串](./problems/0005.最长回文子串.md) 和[647.回文子串](https://mp.weixin.qq.com/s/2WetyP6IYQ6VotegepVpEw) 差不多是一样的\n* [132.分割回文串II](./problems/0132.分割回文串II.md) 与647.回文子串和 5.最长回文子串 很像\n* [673.最长递增子序列的个数](./problems/0673.最长递增子序列的个数.md) \n\n## 图论\n* [463.岛屿的周长](./problems/0463.岛屿的周长.md) （模拟）\n* [841.钥匙和房间](./problems/0841.钥匙和房间.md) 【有向图】dfs，bfs都可以\n* [127.单词接龙](./problems/0127.单词接龙.md) 广搜\n\n## 并查集 \n* [684.冗余连接](./problems/0684.冗余连接.md) 【并查集基础题目】\n* [685.冗余连接II](./problems/0685.冗余连接II.md)【并查集的应用】\n\n## 模拟\n* [657.机器人能否返回原点](./problems/0657.机器人能否返回原点.md) \n* [31.下一个排列](./problems/0031.下一个排列.md) \n\n## 位运算\n* [1356.根据数字二进制下1的数目排序](./problems/1356.根据数字二进制下1的数目排序.md) \n\n\n# 算法模板 \n\n[各类基础算法模板](https://github.com/youngyangyang04/leetcode/blob/master/problems/算法模板.md)\n\n# 贡献者 \n\n[点此这里](https://github.com/youngyangyang04/leetcode-master/graphs/contributors)查看LeetCode-Master的所有贡献者。感谢他们补充了LeetCode-Master的其他语言版本，让更多的读者受益于此项目。\n\n# Star 趋势\n\n[![Star History Chart](https://api.star-history.com/svg?repos=youngyangyang04/leetcode-master\u0026type=Date)](https://star-history.com/#youngyangyang04/leetcode-master\u0026Date)\n\n# 关于作者\n\n大家好，我是程序员Carl，哈工大师兄，《代码随想录》作者，先后在腾讯和百度从事后端技术底层技术研发。\n\n# PDF下载 \n\n添加如下企业微信，会自动发送给大家PDF版本，顺便可以选择是否加入刷题群。 \n\n添加微信记得备注，如果是已工作，备注：姓名-城市-岗位。如果学生，备注：姓名-学校-年级。**备注没有自我介绍不通过哦**\n\n\u003cdiv align=\"center\"\u003e\u003cimg src=\"https://file.kamacoder.com/pics/第二企业刷题活码.png\" data-img=\"1\" width=\"200\" height=\"200\"\u003e\u003c/img\u003e\u003c/div\u003e\n\n","funding_links":[],"categories":["Shell","分类","Others","计算机编程 数据结构与算法","数据结构与算法","Repositories","武器库"],"sub_categories":["算法","网络服务_其他"],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyoungyangyang04%2Fleetcode-master","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fyoungyangyang04%2Fleetcode-master","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyoungyangyang04%2Fleetcode-master/lists"}