LeetCode 刷题顺序,按标签分类,科学刷题!_leetcode刷题顺序-程序员宅基地

技术标签: 算法  leetcode  

https://zhuanlan.zhihu.com/p/501483324

本文已收录Github: imcoderlemon/CodeClass内含 1000 本计算机开源电子书、学习资源、简历面经,欢迎 star

很多初学算法的同学,对着LeetCode从头开刷,结果磕磕碰碰没几个AC。

挫败感上来就刷不动了,其实掌握科学刷题顺序能让你事半功倍!

今天就来总结下正确的刷题顺序,大家跟着刷就行!

在刷题之前,如果时间充足,一定要先了解一道算法题考察的知识点,同一个知识点可以触类旁通,强化联系。下面把Leetcode上的题目按结构化标签分类,供你参考。

一定要按照按照题目类别结构化地刷题 !!!

这样刷题的速度不仅更快,而且可以在刷完一类题之后进行总结。

对于水平较高的小伙伴们来说,按照推荐的顺序刷,可以在 200 小时内刷完 500 多题。

对于萌新们来说,按照推荐顺序刷,能更好地掌握数据结构与算法基础

题目按标签分类

一. 数组

题目分类 题目编号

数组的遍历 485、495、414、628

统计数组中的元素 645、697、448、442、41、274

数组的改变、移动 453、665、283

二维数组及滚动数组 118、119、661、598、419

数组的旋转 189、396

特定顺序遍历二维数组 54、59、498

二维数组变换 566、48、73、289

前缀和数组 303、304、238

题解 数组篇

二. 字符串

题目分类 题目编号

字符 520

回文串的定义 125

公共前缀 14

单词 434、58

字符串的反转 344、541、557、151

字符的统计 387、389、383、242、49、451、423、657、551、696、467、535

数字与字符串间转换 299、412、506、539、553、537、592、640、38、443、8、13、12、273、165、481

子序列 392、524、521、522

高精度运算 66、67、415、43、306

字符串变换 482、6、68

字符串匹配 28、686、459、214

中心拓展法 5、647

三. 数与位

题目分类 题目编号

数字的位操作 7、9、479、564、231、342、326、504、263、190、191、476、461、477、693、393、172、458、258、319、405、171、168、670、233、357、400

简单数学题 492、29、507

快速幂 50、372

四. 栈与递归

题目分类 题目编号

用栈访问最后若干元素 682、71、388

栈与计算器 150、227、224

栈与括号匹配 20、636、591、32

递归 385、341、394

五. 链表

题目分类 题目编号

链表的删除 203、237、19

链表的遍历 430

链表的旋转与反转 61、24、206、92、25

链表高精度加法 2、445

链表的合并 21、23

六. 哈希表

题目分类 题目编号

哈希表的查找、插入及删除 217、633、349、128、202、500、290、532、205、166、466、138

哈希表与索引 1、167、599、219、220

哈希表与统计 594、350、554、609、454、18

哈希表与前缀和 560、523、525

七. 贪心算法

题目分类 题目编号

数组与贪心算法 605、121、122、561、455、575、135、409、621、179、56、57、228、452、435、646、406、48、169、215、75、324、517、649、678、420

子数组与贪心算法 53、134、581、152

子序列与贪心算法 334、376、659

数字与贪心 343

单调栈法 496、503、456、316、402、321、84、85

八. 双指针法

题目分类 题目编号

头尾指针 345、680、167、15、16、18、11、42

同向双指针、滑动窗口 27、26、80、83、82、611、187、643、674、209、3、438、567、424、76、30

分段双指针 86、328、160、88、475

快慢指针 141、142、143、234、457、287

九. 树

题目分类 题目编号

树与递归 100、222、101、226、437、563、617、508、572、543、654、687、87

树的层次遍历 102、429、690、559、662、671、513、515、637、103、107、257、623、653、104、111、112、113、129、404、199、655、116、117

树的前序遍历 144、589

树的前序序列化 606、331、652、297、449

树的后序遍历 145、590

树的中序遍历与二叉搜索树 94、700、530、538、230、98、173、669、450、110、95、108、109

重构二叉树 105、106

二叉树的展开 114

最近公共祖先 235、236

Morris中序遍历 501、99

四叉树 558、427

十. 图与搜索

题目分类 题目编号

图的建立与应用 565

深度优先搜索 17、397

回溯法 526、401、36、37、51、52、77、39、216、40、46、47、31、556、60、491、78、90、79、93、332

回溯法与表达式 241、282、679

回溯法与括号 22、301

回溯法与贪心 488

广度优先搜索 133、200、695、463、542、130、417、529、127、126、433、675

并查集 547、684、685

拓扑排序 399、207、210

有限状态自动机 65、468

十一. 二分查找

题目分类 题目编号

二分查找应用(简单) 374、35、278、367、69、441

二分查找应用(中等) 34、540、275、436、300、354、658、162、4

二分查找与旋转数组 153、154、33、81

二分查找与矩阵 74、240

二分答案法 378、668、410、483

十二. 二进制运算的应用

题目分类 题目编号

异或的应用 89、136、137、260、268

与或非的应用 371、318、201

十三. 动态规划

题目分类 题目编号

数组中的动态规划 509、70、338、45、55、198、213、650、91、639、552、123、188、309、32、264、313、403

子数组、子序列中的动态规划 689、413、446、368、416、279

背包问题 322、518、474、494、377

矩阵中的动态规划 62、63、64、120、576、688、221、629、174、96、329

动态规划与字符串匹配 583、72、97、115、516、132、131、139、140、514、10、44

状态压缩动态规划 464、691、698、638、473

区间中的动态规划 486、664、375、312、546

树形dp 337、124

数位dp 233、600

十四. 数据结构

题目分类 题目编号

数据结构设计——栈与队列 225、232、284、622、641、155

数据结构设计——哈希表 676、355、380、381

数据结构设计——哈希与双向链表 432、146、460

前缀树 208、211、648、386、677、472、421、212、336、440

堆 23、373、378、632、347、692、502、630、407、295、480

树状数组 307、315、493、327、673

线段树 699

平衡树(set/map) 352、218、363

十五. 采样

题目分类 题目编号

按权值采样 528、497

蓄水池抽样 382、398

拒绝采样 470、478、519

十六. 计算几何

题目分类 题目编号

计算几何基础 593、447、223、149

分类讨论法 335

凸包 587

覆盖问题 391

十七. 常用技巧与算法

题目分类 题目编号

博弈论 292

分块 239、164

倍增法 330

拓展欧几里得算法 365

洗牌算法 384

找规律 390、672

分治法 395、667

排序算法 147、148

线性筛 204

摩尔投票法 229

作者:aggie1024 链接: 力扣(LeetCode)刷题顺序很重要

按照这个目录标签分类顺序刷一遍,如果中间有题目卡住了先跳过,然后刷题一遍 LeetCode 探索基础卡片,最后快要面试时刷题一遍剑指 offer。

现在,你对LeetCode上的算法题有了全局的认识,如果时间充足可以按上面的模块分类,逐个专题练习,定期回头巩固。但是,有些同学是为了面试,精力有限的情况下,我推荐你抓住中点去刷题,也就是我接下来要讲的。

面试刷题抓重点

大部分同学刷题是为了面试,在我们精力有限的情况下,并不一定要把上面说的每个模块都完全刷一遍,下面这张图做了比较好的总结,有选择性的刷题,颜色越深面试碰到的概率越高,刷!

图片来自九章算法

下面这张图也做了类似的总结,还给出了大厂考察频率、小公司考察频率,甚至性价比都给你算出来了,还有什么理由不去刷性价比最高的呢!

非常重要的算法模式比如:二分法、二叉树、链表、BFS、DFS、双指针、哈希表、字典树、各种排序,这些必须做到熟练掌握。

图片来自九章算法

另外,算法刷题说实话只是面试考察的一方面,算法基本功很重要,但作为一名计算机基础素养完备的软件工程师,更需要全面的计算机知识体系,比如:计算机组成原理、计算机网络、操作系统、外加一两门语言(C++、Java、Python等等)相关的知识,这些知识构成了你以后技术成长的基石,算法刷的好,还要基础打的牢。

网上学习这些编程知识的资源很多,我建议还是看书成体系化的学习比较好,一路走来学习编程过程中,我看过、收集过非常多的编程书籍。

电子版整合链接:

https://github.com/imcoderlemon/CodeClass/blob/main/1000%E6%9C%AC%E5%BC%80%E6%BA%90%E7%94%B5%E5%AD%90%E4%B9%A6.md

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/fengyuyeguirenenen/article/details/125099023

智能推荐

leetcode-4.17[819. 最常见的单词、1108. IP 地址无效化、55. 跳跃游戏](python解法)_python里为什么会出现这样的结果? >>> -10//3, 10//-3, -10//-3, --程序员宅基地

文章浏览阅读141次。题目1题解1from queue import PriorityQueueclass Solution: def mostCommonWord(self, paragraph: str, banned: List[str]) -> str: pq = PriorityQueue(maxsize=0) for c in "!?',;.": ..._python里为什么会出现这样的结果? >>> -10//3, 10//-3, -10//-3, -(10//3) (-4, -

[569]tf.nn.embedding_lookup函数_tf.nn.embedding_lookup(-程序员宅基地

文章浏览阅读470次。我觉得这张图就够了,实际上tf.nn.embedding_lookup的作用就是找到要寻找的embedding data中的对应的行下的vector。tf.nn.embedding_lookup(params, ids, partition_strategy=‘mod’, name=None, validate_indices=True, max_norm=None)参数说明:par..._tf.nn.embedding_lookup(

Keil4添加STC系列单片机_keil4没有stc怎么办-程序员宅基地

文章浏览阅读6.5k次,点赞6次,收藏18次。俗话说:工欲善其事,必先利其器。在学习一门编程语言之前,我们必须先安装好它的开发环境,由于工作需求不得不去研究C51单片机的知识。下面就开始安装我们的开发环境keil4。1,、打开keil的官网http://www.keil.com/c512、鼠标移到C51V960A.EXE,右键鼠标点击在新标签页打开链接,点击后浏览器就开始下载了(如果你的电脑下载了下载软件,那么就在你的下载软件中下载..._keil4没有stc怎么办

table选项卡原理_table 选项卡-程序员宅基地

文章浏览阅读332次。table选项卡原理$(this).addClass("active").siblings().removeClass("active");_table 选项卡

Linux多线程【初识线程】-程序员宅基地

文章浏览阅读1.6k次,点赞98次,收藏94次。将一份代码成功编译后,可以得到一个可执行程序,程序运行后,相关代码和数据被load到内存中,并且操作系统会生成对应数据结构(比如PCB)对其进行管理及分配资源,准备工作做完之后,我们就可以得到一个运行中的程序,简称为进程,对于操作系统来说,光有进程的概念是无法满足高效运行的需求的,因此需要一种执行粒度更细、调度成本更低的执行流,而这就是线程Windows中的线程

【matlab】QR分解_matlab qr分解-程序员宅基地

文章浏览阅读2.5k次,点赞25次,收藏29次。这说明对于垂直于w的向量,householder变换的作用就是对其不起任何作用,那么对于一个普通的向量v来说,平行于w的分量被householder反向,垂直于w的分量不变,那么最终的效果就是将向量v作关于法向量为w的平面的镜像对称。给定一个m×n的矩阵A,其中m≥n,即矩阵A是高矩阵或者是方阵,QR分解将矩阵A分解为两个矩阵Q和R的乘积,其中矩阵Q是一个m×n的各列正交的矩阵,即QTQ=I,矩阵R是一个n×n的上三角矩阵,其对角线元素为正。,an是线性无关的,而且得到了一个正交向量组q1,q2,_matlab qr分解

随便推点

Zabbix5.4、6.0、6.2、6.4、7.0路线图一览!5.4将于下月发布!_zabbix 发布 时间-程序员宅基地

文章浏览阅读3.9k次,点赞4次,收藏3次。Zabbix5.4、6.0、6.2、6.4、7.0路线图新鲜发布!APM、安全性和合规性监控、高级事件关联和企业告警控制台、客户门户、日志管理、新增的可视化和报告、云本地可扩展性和HA等等!Zabbix的长期路线图更新丰富,一睹为快!Zabbix官方培训将在上海、北京、深圳、广州举办,短时间内系统学习,深入掌握,更好地将Zabbix应用到工作中!..._zabbix 发布 时间

org.springframework.beans.factory.BeanDefinitionStoreException: Failed to read candidate component-程序员宅基地

文章浏览阅读6k次,点赞7次,收藏5次。前两天接手公司Dorado项目,由于IDEA中没有 Dorado插件,无奈又下载了eclipse(ps:个人还是比较喜欢用idea的)eclipse带Dorado插件的链接:https://pan.baidu.com/s/1SayfdnlWELGuY9AE6BTiKg 提取码:t7vw刚接手Dorado,不太熟找个例子试下,Dorado文档,根据文档介绍,笔者一步一步的开始搭建项目,..._org.springframework.beans.factory.beandefinitionstoreexception: failed to re

数字图像处理-基本知识总结_数字图像处理学习-程序员宅基地

文章浏览阅读490次。我们人类在从不同距离,不同方向,不同光照条件下观察一个物体时,虽然这个物体的大小,形状,明暗都会有不同,但是我们仍然可以判断出,它们是同一个物体。由于图片中存在噪声,导数对噪声敏感,如果直接提取边缘,会有许多噪声的地方也会出现极值,所以先用高斯平滑滤波,可以突出图片中边缘,去除噪声;注:由于提取边缘用的高斯滤波,高斯平滑函数的σ决定高斯函数的胖瘦和高低,即决定边缘提取的精度,σ越小,边缘提取越精确。由于图片中的边缘是分布在不同方向上的,比如横着方向提取的边缘,表示图片在这一区域的像素值,横着方向变化剧烈。_数字图像处理学习

逻辑分析仪Kingst第一天_kingstvis-程序员宅基地

文章浏览阅读5.9k次,点赞3次,收藏14次。1、安装软件——KingstVISKingstVSI软件安装地址没有安装难度,就一顿下一步就行,有个驱动安装窗口一定要点安装2、软件安装完,界面如下图:包含4部分:工具栏、通道设备栏、波形显示窗口、采样结果分析窗口..._kingstvis

实践中学习vim之vim配置文件、插件文件加载路径_gvim 添加脚本加载路径-程序员宅基地

文章浏览阅读1.6k次。From:http://blog.csdn.net/smstong/article/details/205672350 引言理解vim的启动过程对于增强使用vim的信心非常重要,本文所有的信息均来自vim自身提供的参考手册和作者实际操作实践。VIM REFERENCE MANUAL的Starting Vim这节详细描述了vim的启动过程。vim完整的启动过程非常复杂,因为要_gvim 添加脚本加载路径

推荐文章

热门文章

相关标签