1.数据结构
💡 LeetCode 高频面试题分类列表,总共24类,312道题目! |
---|
图
- [ ] 133.克隆图
- [ ] 207.课程表
- [ ] 210.课程表 II
- [ ] 399.除法求值
- [ ] 547.省份数量
- [ ] 684.冗余连接
- [ ] 743.网络延迟时间
- [ ] 785.判断二分图
堆
- [ ] 215.数组中的第K个最大元素
- [ ] 295.数据流的中位数
- [ ] 264.丑数 II
- [ ] 347.前 K 个高频元素
- [ ] 378.有序矩阵中第 K 小的元素
- [ ] 703.数据流中的第 K 大元素
- [ ] 767.重构字符串
- [ ] 剑指 Offer 41.数据流中的中位数
栈
- [ ] 20.有效的括号
- [ ] 71.简化路径
- [ ] 84.柱状图中最大的矩形
- [ ] 85.最大矩形
- [ ] 155.最小栈
- [ ] 224.基本计算器
- [ ] 227.基本计算器 II
- [ ] 394.字符串解码
- [ ] 402.移掉 K 位数字
- [ ] 503.下一个更大元素 II
- [ ] 739.每日温度
- [ ] 1047.删除字符串中的所有相邻重复项
- [ ] 剑指 Offer 06.从尾到头打印链表
- [ ] 剑指 Offer 30.包含min函数的栈
- [ ] 剑指 Offer 31.栈的压入、弹出序列
队列
- [ ] 225.用队列实现栈
- [ ] 232.用栈实现队列
- [ ] 239.滑动窗口最大值
- [ ] 387.字符串中的第一个唯一字符
- [ ] 622.设计循环队列
- [ ] 862.和至少为 K 的最短子数组
- [ ] 933.最近的请求次数
- [ ] 剑指 Offer 09.用两个栈实现队列
- [ ] 剑指 Offer 59 - I.滑动窗口的最大值
- [ ] 剑指 Offer 59 - II.队列的最大值
链表
- [ ] 2.两数相加
- [ ] 25.K 个一组翻转链表
- [ ] 82.删除排序链表中的重复元素 II
- [ ] 83.删除排序链表中的重复元素
- [ ] 86.分隔链表
- [ ] 92.反转链表 II
- [ ] 138.复制带随机指针的链表
- [ ] 143.重排链表
- [ ] 160.相交链表
- [ ] 328.奇偶链表
- [ ] 445.两数相加 II
- [ ] 876.链表的中间结点
- [ ] 剑指 Offer 22.链表中倒数第k个节点
- [ ] 剑指 Offer 24.反转链表
- [ ] 剑指 Offer 52.两个链表的第一个公共节点
数组
- [ ] 1.两数之和
- [ ] 31.下一个排列
- [ ] 33.搜索旋转排序数组
- [ ] 41.缺失的第一个正数
- [ ] 56.合并区间
- [ ] 162.寻找峰值
- [ ] 189.轮转数组
- [ ] 560.和为 K 的子数组
- [ ] 695.岛屿的最大面积
- [ ] 剑指 Offer 66.构建乘积数组
矩阵
- [ ] 36.有效的数独
- [ ] 37.解数独
- [ ] 48.旋转图像
- [ ] 54.螺旋矩阵
- [ ] 59.螺旋矩阵 II
- [ ] 73.矩阵置零
- [ ] 74.搜索二维矩阵
- [ ] 240.搜索二维矩阵 II
- [ ] 733.图像渲染
- [ ] 剑指 Offer 04.二维数组中的查找
- [ ] 剑指 Offer 29.顺时针打印矩阵
字符串
- [ ] 6.Z 字形变换
- [ ] 12.整数转罗马数字
- [ ] 14.最长公共前缀
- [ ] 28.实现 strStr()
- [ ] 58.最后一个单词的长度
- [ ] 115.不同的子序列
- [ ] 151.颠倒字符串中的单词
- [ ] 344.反转字符串
- [ ] 443.压缩字符串
- [ ] 459.重复的子字符串
- [ ] 556.下一个更大元素 III
- [ ] 557.反转字符串中的单词 III
- [ ] 647.回文子串
- [ ] 678.有效的括号字符串
- [ ] 680.验证回文字符串 Ⅱ
- [ ] 剑指 Offer 05.替换空格
- [ ] 剑指 Offer 20.表示数值的字符串
- [ ] 剑指 Offer 67.把字符串转换成整数
哈希表
- [ ] 49.字母异位词分组
- [ ] 202.快乐数
- [ ] 204.计数质数
- [ ] 692.前K个高频单词
- [ ] 706.设计哈希映射
- [ ] 895.最大频率栈
- [ ] 974.和可被 K 整除的子数组
- [ ] 1044.最长重复子串
- [ ] 剑指 Offer 03.数组中重复的数字
- [ ] 剑指 Offer 35.复杂链表的复制
- [ ] 面试题50.第一个只出现一次的字符
二叉树
- [ ] 94.二叉树的中序遍历
- [ ] 100.相同的树
- [ ] 108.将有序数组转换为二叉搜索树
- [ ] 116.填充每个节点的下一个右侧节点指针
- [ ] 117.填充每个节点的下一个右侧节点指针 II
- [ ] 144.二叉树的前序遍历
- [ ] 144.二叉树的前序遍历
- [ ] 222.完全二叉树的节点个数
- [ ] 226.翻转二叉树
- [ ] 236.二叉树的最近公共祖先
- [ ] 297.二叉树的序列化与反序列化
- [ ] 404.左叶子之和
- [ ] 450.删除二叉搜索树中的节点
- [ ] 501.二叉搜索树中的众数
- [ ] 508.出现次数最多的子树元素和
- [ ] 530.二叉搜索树的最小绝对差
- [ ] 538.把二叉搜索树转换为累加树
- [ ] 543.二叉树的直径
- [ ] 617.合并二叉树
- [ ] 637.二叉树的层平均值
- [ ] 654.最大二叉树
- [ ] 662.二叉树最大宽度
- [ ] 669.修剪二叉搜索树
- [ ] 700.二叉搜索树中的搜索
- [ ] 701.二叉搜索树中的插入操作
- [ ] 889.根据前序和后序遍历构造二叉树
- [ ] 958.二叉树的完全性检验
- [ ] 剑指 Offer 27.二叉树的镜像
- [ ] 剑指 Offer 54.二叉搜索树的第k大节点
- [ ] 剑指 Offer 68 - I.二叉搜索树的最近公共祖先
- [ ] 剑指 Offer 68 - II.二叉树的最近公共祖先
广度优先搜索
- [ ] 102.二叉树的层序遍历
- [ ] 103.二叉树的锯齿形层序遍历
- [ ] 107.二叉树的层序遍历 II
- [ ] 111.二叉树的最小深度
- [ ] 310.最小高度树
- [ ] 513.找树左下角的值
- [ ] 剑指 Offer 32 - II.从上到下打印二叉树 II
- [ ] 剑指 Offer 32 - III.从上到下打印二叉树 III
- [ ] 剑指 Offer 37.序列化二叉树
深度优先搜索
- [ ] 99.恢复二叉搜索树
- [ ] 101.对称二叉树
- [ ] 105.从前序与中序遍历序列构造二叉树
- [ ] 106.从中序与后序遍历序列构造二叉树
- [ ] 109.有序链表转换二叉搜索树
- [ ] 114.二叉树展开为链表
- [ ] 257.二叉树的所有路径
- [ ] 301.删除无效的括号
- [ ] 剑指 Offer 12.矩阵中的路径
- [ ] 剑指 Offer 17.打印从1到最大的n位数
- [ ] 剑指 Offer 34.二叉树中和为某一值的路径
- [ ] 剑指 Offer 55 - I.二叉树的深度
- [ ] 剑指 Offer 55 - II.平衡二叉树
滑动窗口
- [ ] 3.无重复字符的最长子串
- [ ] 187.重复的DNA序列
- [ ] 219.存在重复元素 II
- [ ] 220.存在重复元素 III
- [ ] 1004.最大连续1的个数 III
- [ ] 剑指 Offer 48.最长不含重复字符的子字符串
- [ ] 剑指 Offer 57 - II.和为s的连续正数序列
- [ ] 剑指 Offer 58 - I.翻转单词顺序
动态规划
- [ ] 5.最长回文子串
- [ ] 32.最长有效括号
- [ ] 62.不同路径
- [ ] 63.不同路径 II
- [ ] 64.最小路径和
- [ ] 70.爬楼梯
- [ ] 72.编辑距离
- [ ] 91.解码方法
- [ ] 96.不同的二叉搜索树
- [ ] 97.交错字符串
- [ ] 120.三角形最小路径和
- [ ] 121.买卖股票的最佳时机
- [ ] 122.买卖股票的最佳时机 II
- [ ] 123.买卖股票的最佳时机 III
- [ ] 139.单词拆分
- [ ] 152.乘积最大子数组
- [ ] 198.打家劫舍
- [ ] 213.打家劫舍 II
- [ ] 221.最大正方形
- [ ] 279.完全平方数
- [ ] 300.最长递增子序列
- [ ] 322.零钱兑换
- [ ] 337.打家劫舍s III
- [ ] 343.整数拆分
- [ ] 410.分割数组的最大值
- [ ] 494.目标和
- [ ] 516.最长回文子序列
- [ ] 518.零钱兑换 II
- [ ] 673.最长递增子序列的个数
- [ ] 718.最长重复子数组
- [ ] 1143.最长公共子序列
- [ ] 剑指 Offer 14- I.剪绳子
- [ ] 剑指 Offer 14- II.剪绳子 II
- [ ] 剑指 Offer 46.把数字翻译成字符串
- [ ] 剑指 Offer 47.礼物的最大价值
- [ ] 剑指 Offer 49.丑数
- [ ] 剑指 Offer 60.n个骰子的点数
- [ ] 剑指 Offer 63.股票的最大利润
二分查找
- [ ] 4.寻找两个正序数组的中位数
- [ ] 33.搜索旋转排序数组
- [ ] 34.在排序数组中查找元素的第一个和最后一个位置
- [ ] 50.Pow(x, n)
- [ ] 69.x 的平方根
- [ ] 153.寻找旋转排序数组中的最小值
- [ ] 162.寻找峰值
- [ ] 230.二叉搜索树中第K小的元素
- [ ] 287.寻找重复数
- [ ] 349.两个数组的交集
- [ ] 704.二分查找
- [ ] 剑指 Offer 11.旋转数组的最小数字
- [ ] 剑指 Offer 53 - I.在排序数组中查找数字 I
- [ ] 剑指 Offer 53 - II.0~n-1中缺失的数字
双指针
- [ ] 3.无重复字符的最长子串
- [ ] 11.盛最多水的容器
- [ ] 15.三数之和
- [ ] 19.删除链表的倒数第 N 个结点
- [ ] 26.删除有序数组中的重复项
- [ ] 42.接雨水
- [ ] 61.旋转链表
- [ ] 75.颜色分类
- [ ] 76.最小覆盖子串
- [ ] 88.合并两个有序数组
- [ ] 125.验证回文串
- [ ] 141.环形链表
- [ ] 142.环形链表 II
- [ ] 209.长度最小的子数组
- [ ] 234.回文链表
- [ ] 283.移动零
- [ ] 剑指 Offer 04.二维数组中的查找
- [ ] 剑指 Offer 18.删除链表的节点
- [ ] 剑指 Offer 21.调整数组顺序使奇数位于偶数前面
- [ ] 剑指 Offer 22.链表中倒数第k个节点
- [ ] 剑指 Offer 58 - I.翻转单词顺序
并查集
- [ ] 128.最长连续序列
- [ ] 130.被围绕的区域
- [ ] 200.岛屿数量
位运算
- [ ] 136.只出现一次的数字
- [ ] 137.只出现一次的数字 II
- [ ] 191.位1的个数
- [ ] 231.2 的幂
- [ ] 260.只出现一次的数字 III
- [ ] 268.丢失的数字
- [ ] 405.数字转换为十六进制数
- [ ] 剑指 Offer 15.二进制中1的个数
- [ ] 剑指 Offer 56 - I.数组中数字出现的次数
- [ ] 剑指 Offer 56 - II.数组中数字出现的次数 II
- [ ] 剑指 Offer 65.不用加减乘除做加法
分治
- [ ] 23.合并K个升序链表
- [ ] 53.最大子数组和
- [ ] 169.多数元素
- [ ] 剑指 Offer 42.连续子数组的最大和
- [ ] 剑指 Offer 36.二叉搜索树与双向链表
- [ ] 剑指 Offer 39.数组中出现次数超过一半的数字
回溯
- [ ] 10.正则表达式匹配
- [ ] 17.电话号码的字母组合
- [ ] 22.括号生成
- [ ] 39.组合总和
- [ ] 40.组合总和 II
- [ ] 46.全排列
- [ ] 47.全排列 II
- [ ] 51.N 皇后
- [ ] 60.排列序列
- [ ] 77.组合
- [ ] 78.子集
- [ ] 79.单词搜索
- [ ] 89.格雷编码
- [ ] 93.复原 IP 地址
- [ ] 140.单词拆分 II
- [ ] 306.累加数
- [ ] 剑指 Offer 13.机器人的运动范围
- [ ] 剑指 Offer 38.字符串的排列
贪心
- [ ] 44.通配符匹配
- [ ] 45.跳跃游戏 II
- [ ] 55.跳跃游戏
- [ ] 134.加油站
- [ ] 135.分发糖果
- [ ] 316.去除重复字母
- [ ] 763.划分字母区间
排序
- [ ] 148.排序链表
- [ ] 164.最大间距
- [ ] 179.最大数
- [ ] 242.有效的字母异位词
- [ ] 315.计算右侧小于当前元素的个数
- [ ] 剑指 Offer 40.最小的k个数
- [ ] 剑指 Offer 45.把数组排成最小的数
- [ ] 剑指 Offer 51.数组中的逆序对
- [ ] 剑指 Offer 61.扑克牌中的顺子
递归
- [ ] 2.两数相加
- [ ] 21.合并两个有序链表
- [ ] 24.两两交换链表中的节点
- [ ] 98.验证二叉搜索树
- [ ] 104.二叉树的最大深度
- [ ] 110.平衡二叉树
- [ ] 124.二叉树中的最大路径和
- [ ] 199.二叉树的右视图
- [ ] 剑指 Offer 07.重建二叉树
- [ ] 剑指 Offer 10- I.斐波那契数列
- [ ] 剑指 Offer 10- II.青蛙跳台阶问题
- [ ] 剑指 Offer 26.树的子结构
- [ ] 剑指 Offer 28.对称的二叉树
- [ ] 剑指 Offer 64.求1+2+…+n
数学
- [ ] 7.整数反转
- [ ] 8.字符串转换整数 (atoi)
- [ ] 9.回文数
- [ ] 43.字符串相乘
- [ ] 166.分数到小数
- [ ] 168.Excel表列名称
- [ ] 171.Excel 表列序号
- [ ] 400.第 N 位数字
- [ ] 670.最大交换
- [ ] 剑指 Offer 16.数值的整数次方
- [ ] 剑指 Offer 43.1~n 整数中 1 出现的次数
- [ ] 剑指 Offer 44.数字序列中某一位的数字
- [ ] 剑指 Offer 62.圆圈中最后剩下的数字