TuTOU123comTuTOU123com
主页
  • 后端

    • 八股文
    • 博客
  • 网站

    • Java
    • SpringCloud
    • Gitee
Ai工具
  • 星球地址
  • 星球精华
关于
  • 个人感悟
  • 个人成长
  • 简体中文
  • English
GitHub
主页
  • 后端

    • 八股文
    • 博客
  • 网站

    • Java
    • SpringCloud
    • Gitee
Ai工具
  • 星球地址
  • 星球精华
关于
  • 个人感悟
  • 个人成长
  • 简体中文
  • English
GitHub
  • 目录

    • 1.数据结构
      • 图
      • 堆
      • 栈
      • 队列
      • 链表
      • 数组
      • 矩阵
      • 字符串
      • 哈希表
      • 二叉树
      • 广度优先搜索
      • 深度优先搜索
      • 滑动窗口
      • 动态规划
      • 二分查找
      • 双指针
      • 并查集
      • 位运算
      • 分治
      • 回溯
      • 贪心
      • 排序
      • 递归
      • 数学
    • 2.java基础
    • 3.集合
    • 4.Mysql
    • 5.多线程
    • 6.Redis
    • 7.微服务架构
    • 8.Git+Maven+Jwt+Nginx

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.圆圈中最后剩下的数字
Edit this page
Last Updated: 7/4/2024, 8:14:20 AM
Contributors: swp
Next
2.java基础