LeetCode刷题经验分享

大彬
大约 4 分钟

分享几点我自己的刷题经验,看看我是如何在最短时间内搞定数据结构与算法,达到应付面试的程度的。

主要有以下3点技巧:

  1. 按题目分类来刷
  2. 难度要循序渐进
  3. 做好总结

按题目分类刷题

LeetCode上面的题目都有进行分类,建议在一个时间段只刷同一类型的题目,可以更全面的认识这一类型的数据结构or算法,以加深对此类题型的理解。就好比练功夫,前期把一些基本招式都熟悉掌握,后面再串通这些招式,融会贯通。

我个人也是比较习惯按照分类来刷题,自我感觉效果还可以。

我将LeetCode题目进行了整理分类,大家可以参考下(以下出现的题型都是需要掌握的):

数组操作

  • LeetCode54 螺旋矩阵
  • LeetCode76 最小覆盖子串
  • LeetCode75 颜色分类
  • LeetCode73 矩阵置零
  • LeetCode384 打乱数组
  • LeetCode581 最短无序连续子数组
  • LeetCode945 使数组唯一的最小增量

链表操作

  • LeetCode206 反转链表
  • LeetCode19 删除链表的倒数第N个节点
  • LeetCode25 k个一组翻转链表
  • LeetCode141 环形链表
  • LeetCode142 环形链表Ⅱ
  • LeetCode61 旋转链表
  • LeetCode138 复制带随机指针的链表
  • LeetCode160 相交链表
  • LeetCode707 设计链表

  • LeetCode20 有效的括号
  • LeetCode32 最长有效括号
  • LeetCode155 最小栈
  • LeetCode224 基本计算器
  • LeetCode232 用栈实现队列
  • LeetCode316 去除重复字母

树的遍历

  • LeetCode94 二叉树的中序遍历
  • LeetCode102 二叉树的层次遍历
  • LeetCode110 平衡二叉树
  • LeetCode144 二叉树的前序遍历
  • LeetCode145 二叉树的后序遍历

二叉搜索树

  • LeetCode98 验证二叉搜索树
  • LeetCode450 删除二叉搜索树中的节点
  • LeetCode701 二叉搜索树中的插入操作

递归

  • LeetCode21 合并两个有序链表
  • LeetCode101 对称二叉树
  • LeetCode104 二叉树的最大深度
  • LeetCode226 翻转二叉树
  • LeetCode236 二叉树的最近公共祖先

双指针/滑动窗口

  • LeetCode3 无重复字符的最长子串
  • LeetCode11 盛最多水的容器
  • LeetCode15 三数之和
  • LeetCode16 最接近的三数之和
  • LeetCode26 删除排序数组中的重复项
  • LeetCode42 接雨水
  • LeetCode121 买卖股票的最佳时机
  • LeetCode209 长度最小的子数组

快慢指针遍历

  • LeetCode141 环形链表
  • LeetCode202 快乐数
  • LeetCode876 链表的中间结点

动态规划

  • LeetCode5 最长回文子串
  • LeetCode53 最大子序和
  • LeetCode62 不同路径
  • LeetCode64 最小路径和
  • LeetCode70 爬楼梯
  • LeetCode118 杨辉三角
  • LeetCode300 最长上升子序列
  • LeetCode1143 最长公共子序列

回溯算法

  • LeetCode10 正则表达式匹配
  • LeetCode22 括号生成
  • LeetCode40 组合总和2
  • LeetCode46 全排列

贪心算法

  • LeetCode 11. 盛最多水的容器
  • LeetCode 406. 根据身高重建队列
  • LeetCode 55. 跳跃游戏
  • LeetCode 122. 买卖股票的最佳时机 II
  • LeetCode 309. 最佳买卖股票时机含冷冻期
  • LeetCode 714. 买卖股票的最佳时机含手续费

并查集

  • LeetCode200 岛屿的个数
  • LeetCode547 省份数量

位运算

  • LeetCode52 N皇后Ⅱ
  • LeetCode338 比特位计数
  • LeetCode191 位1的个数
  • LeetCode231 2的幂

难度要循序渐进

这一点是针对初学者来说的,切记一上来就干hard级别的题目,会让你怀疑人生的。。。

正确的做法是循序渐进,从容易到中等,再过渡到困难级别。不过国内大厂考察算法,一般都是中等难度,困难级别的应该很少考察。

做好总结

多做总结!多做总结!多做总结!

做好总结很重要,特别是对于没思路的题目,看了其他大佬的解法之后,多思考有哪些题目也是类似解法,这种题目的关键解题步骤,把自己的理解写下来,方便自己日后查看。

虽然总结可能会花费你半个钟甚至更多的时间,但是不总结的话,下次你遇到这个题目,可能会花更多的时间去思考、解答。

Loading...