鬼知道我能坚持多久......
期末考试后继续开刷!!!
集成单元测试环境开始写测试以及将项目源代码移入 src 项目文件夹中
从今年 1.7 日开始刷 leetcode 到现在 7.12 过了半年左右吧,刷了将近 340 道,这接下来的两个月不准备继续往下刷了,准备回过来复盘,顺便把之前没写的单元测试写一下。
加入js面试常问的手写题
加入 python 版本继续刷!
.vscode # vscode 配置
code # 一些模板代码
src # 源代码 里面是 leetcode 每一题
20-有效的括号 # leetcode 里面的题目
index.js # js 代码,里面可能有多种解法就新建了 index1.js 这种文件,也有解法在同一个 index.js 中
index.spec.js # 写的单元测试
README.md # 题解
test # 想着写单元测试重新写一个文件夹,后觉得不方便就都写在 src 里面的题目文件夹里面了
weekly-race # leetcode 周赛 ,卑微的写个签到题每次
README # 写的项目介绍以及题目还有更新的细节
.babelrc # 让 jest 中支持 esm 语法
handwriting-js # js面试常问的手写题
141-环形链表
142-环形链表2
202-快乐数
206-反转链表
92-反转链表2
25-K个一组反转链表
61-旋转链表
24-两两交换链表中的节点
19-删除链表的倒数第N个结点
83-删除排序链表中的重复元素
82-删除排序链表中的重复元素2
138-复制带随机指针的链表
86-分隔链表
2-两数相加
160-相交链表
328-奇偶链表
234-回文链表
143-重排链表
21-合并两个有序链表
147-对链表进行插入排序
148-排序链表
剑指 Offer 18. 删除链表的节点
剑指 Offer 06. 从尾到头打印链表
725-分隔链表
剑指 Offer 25. 合并两个排序的链表
203-移除链表元素
237-删除链表中的节点
23-合并K个升序链表
622-设计循环队列
933-最近的请求次数
面试题 17.09. 第 k 个数<归并>
859-亲密字符串
860-柠檬水找零<贪心>
969-煎饼排序
621-任务调度器<优先队列>
429-N 叉树的层序遍历 (数的广度优先用队列)
682-棒球比赛
844-比较含退格的字符串
946-验证栈序列<背板子>
20-有效的括号
1249-移除无效的括号<!>
1021-删除最外层的括号
145-二叉树的后序遍历<非递归实现-栈实现>
331-验证二叉树的前序序列化
227-基本计算器 II<边界多的恶心人>
636-函数的独占时间
1124-表现良好的最长时间段<二刷仍不理解>
445-两数相加 II
71-简化路径
32-最长有效括号
112-路径总和
144-二叉树的前序遍历
94-二叉树的中序遍历
589-N 叉树的前序遍历
226-翻转二叉树
剑指 Offer 32 - II. 从上到下打印二叉树 II
107-二叉树的层序遍历 II
103-二叉树的锯齿形层序遍历
110-平衡二叉树
105-从前序与中序遍历序列构造二叉树
222-完全二叉树的节点个数
剑指 Offer 54. 二叉搜索树的第k大节点
100-相同的树
剑指 Offer 26. 树的子结构
230-二叉搜索树中第K小的元素
101-对称二叉树
104-二叉树的最大深度
111-二叉树的最小深度
236-二叉树的最近公共祖先
108-将有序数组转换为二叉搜索树<跟1382相似度很大,都是构造avl树>
450-删除二叉搜索树中的节点
98-验证二叉搜索树
102-二叉树的层序遍历
235-二叉搜索树的最近公共祖先
257-二叉树的所有路径
404-左叶子之和
113-路径总和 II
114-二叉树展开为链表
116-填充每个节点的下一个右侧节点指针
117-填充每个节点的下一个右侧节点指针 II
129-求根节点到叶节点数字之和
199-二叉树的右视图
437-路径总和 III
993-二叉树的堂兄弟节点
1367-二叉树中的列表
958-二叉树的完全性检验
95-不同的二叉搜索树 II
16-最接近的三数之和 167-两数之和 II - 输入有序数组 455-分发饼干 392-判断子序列 524-通过删除字母匹配到字典里最长单词 415-字符串相加 15-三数之和 18-四数之和 面试题 01.05. 一次编辑 1446-连续字符 11-盛最多水的容器 31-下一个排列 38-外观数列 165-比较版本号
70-爬楼梯 79-单词搜索<回溯> 40-组合总和 II<超时> 77-组合
1768-交替合并字符串
67-二进制求和
88-合并两个有序数组
125-验证回文串
163-缺失的区间
150-逆波兰表达式求值
171-Excel 表列序号
205-同构字符串
217-存在重复元素
219-存在重复元素 II
228-汇总区间
240-搜索二维矩阵 II
744-寻找比目标字母大的最小字母
242-有效的字母异位词
258-各位相加
762-二进制表示中质数个计算置位
263-丑数
268-丢失的数字
278-第一个错误的版本
283-移动零
290-单词规律
169-多数元素
796-旋转字符串
292-Nim 游戏
326-3 的幂
338-比特位计数
342-4的幂
344-反转字符串
345-反转字符串中的元音字母
349-两个数组的交集
367-有效的完全平方数
374-猜数字大小
383-赎金信
387-字符串中的第一个唯一字符
5-最长回文子串
409-最长回文串
806-写字符串需要的行数
412-Fizz Buzz
434-字符串中的单词数
441-排列硬币
448-找到所有数组中消失的数字
128-最长连续序列
501-二叉搜索树中的众数
461-汉明距离
476-数字的补数
386-字典序排数<深度优先>
821-字符的最短距离
824-山羊拉丁文
17-电话号码的字母组合
43-字符串相乘
56-合并区间
57-插入区间
75-颜色分类
395-至少有 K 个重复字符的最长子串<分治 + 递归>
190-颠倒二进制位
6-Z 字形变换
8-字符串转换整数 (atoi)
7-整数反转
9-回文数
12-整数转罗马数字<枚举>
13-罗马数字转整数<枚举>
54-螺旋矩阵<找规律>
59-螺旋矩阵 II<找规律>
90-子集 II<二进制>
118-杨辉三角<找规律>
119-杨辉三角 II<找规律>
36-有效的数独<模拟>
48-旋转图像<找规律>
73-矩阵置零
122-买卖股票的最佳时机 II<脑筋急转弯>
剑指 Offer 40. 最小的k个数 1046-最后一块石头的重量 215-数组中的第K个最大元素
303-区域和检索 - 数组不可变 304-二维区域和检索 - 矩阵不可变 53-最大子数组和<或dp>
172-阶乘后的零
https://www.bilibili.com/video/BV1YT4y117AH?p=1&vd_source=605eaae8506df36fc86fca9b2b498d80 231-2 的幂 342-4的幂 191-位1的个数 面试题 16.01. 交换数字 136-只出现一次的数字 461-汉明距离 693-交替位二进制数 1863-找出所有子集的异或总和再求和 371-两整数之和
705-设计哈希集合 706-设计哈希映射 442-数组中重复的数据
997-小镇法官
https://github.com/vortesnail/leetcode
- 二分查找 已刷完
- 查找表 已刷完
- 滑动窗口
- 链表 已刷完
- LRU 缓存机制
- 前缀和
- 二叉树 已刷完
- DFS 已刷完
- BFS 已刷完<除去前三题是用动态规划>
- 双指针
- 递归与回溯
- 子集 组合
- 全排列
- 搜索
- 分割
- 动态规划 已刷完
- 栈 已刷完
- 排序 已刷完
547-省份数量
200-岛屿数量
990-等式方程的可满足性
684-冗余连接
1319-连通网络的操作次数
128-最长连续序列
947-移除最多的同行或同列石头
TODO:
1202-交换字符串中的元素
542-01 矩阵
1091-二进制矩阵中的最短路径
752-打开转盘锁
剑指 Offer 13. 机器人的运动范围
130-被围绕的区域
494-目标和
473-火柴拼正方形
39-组合总和
78-子集
46-全排列
47-全排列 II
515-在每个树行中找最大值
93-复原 IP 地址
200-岛屿数量
239-滑动窗口最大值
862-和至少为 K 的最短子数组
155-最小栈
503-下一个更大元素 II
901-股票价格跨度
739-每日温度
84-柱状图中最大的矩形
1856-子数组最小乘积的最大值
496-下一个更大元素 I
TODO:
907-子数组的最小值之和
456-132 模式 !!!bug
42-接雨水!!!
402-移掉 K 位数字
面试题 16.11. 跳水板 1291-顺次数 22-括号生成
50-Pow(x, n) 69-x 的平方根 704-二分查找 33-搜索旋转排序数组 4-寻找两个正序数组的中位数 34-在排序数组中查找元素的第一个和最后一个位置 74-搜索二维矩阵 1-两数之和(二分法) 1658-将 x 减到 0 的最小操作数 475-供暖器 81-搜索旋转排序数组 II(不排序的二分)
面试题 04.06. 后继者
450-删除二叉搜索树中的节点
1382-将二叉树变平衡
面试题 17.12. BiNode
剑指 Offer 33. 二叉搜索树的后序遍历序列<有点意思>
1008-前序遍历构造二叉搜索树
TODO:
面试题 04.09. 二叉搜索树序列
1-两数之和 389-找不同 350-两个数组的交集 II
教程: https://www.bilibili.com/video/BV14Q4y1P7Np?from=search&seid=17523386858009450182&spm_id_from=333.337.0.0
239-滑动窗口最大值
438-找到字符串中所有字母异位词
76-最小覆盖子串
3-无重复字符的最长子串
209-长度最小的子数组
剑指 Offer 59 - I. 滑动窗口的最大值
剑指 Offer 59 - II. 队列的最大值
713-乘积小于 K 的子数组
220-存在重复元素 III
187-重复的DNA序列
30-串联所有单词的子串 --- 没过!
1438-绝对差不超过限制的最长连续子数组
1004-最大连续1的个数 III
485-最大连续 1 的个数
剑指 Offer 24. 反转链表 剑指 Offer 05. 替换空格 剑指 Offer 58 - II. 左旋转字符串 剑指 Offer 03. 数组中重复的数字 剑指 Offer 53 - I. 在排序数组中查找数字 I 剑指 Offer 53 - II. 0~n-1中缺失的数字 剑指 Offer 11. 旋转数组的最小数字 面试题50. 第一个只出现一次的字符 面试题32 - I. 从上到下打印二叉树 剑指 Offer 32 - III. 从上到下打印二叉树 III 剑指 Offer 27. 二叉树的镜像 剑指 Offer 28. 对称的二叉树 剑指 Offer 17. 打印从1到最大的n位数 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 剑指 Offer 22. 链表中倒数第k个节点 剑指 Offer 39. 数组中出现次数超过一半的数字 剑指 Offer 57. 和为s的两个数字 剑指 Offer 57 - II. 和为s的连续正数序列 剑指 Offer 58 - I. 翻转单词顺序 剑指 Offer 61. 扑克牌中的顺子 剑指 Offer 07. 重建二叉树 剑指 Offer II 029. 排序的循环链表 剑指 Offer II 012. 左右两边子数组的和相等 剑指 Offer II 019. 最多删除一个字符得到回文 剑指 Offer II 052. 展平二叉搜索树 剑指 Offer II 056. 二叉搜索树中两个节点之和 剑指 Offer 67. 把字符串转换成整数 剑指 Offer 55 - II. 平衡二叉树 剑指 Offer 34. 二叉树中和为某一值的路径 剑指 Offer II 037. 小行星碰撞 剑指 Offer II 074. 合并区间 剑指 Offer II 045. 二叉树最底层最左边的值 剑指 Offer 04. 二维数组中的查找 剑指 Offer 09. 用两个栈实现队列 剑指 Offer 10- I. 斐波那契数列 剑指 Offer 12. 矩阵中的路径 剑指 Offer 42. 连续子数组的最大和 剑指 Offer 64. 求1+2+…+n 剑指 Offer 65. 不用加减乘除做加法 剑指 Offer 46. 把数字翻译成字符串 剑指 Offer 14- I. 剪绳子 剑指 Offer 49. 丑数
64-最小路径和<递归爆栈>
120-三角形最小路径和
198-打家劫舍
53-最大子数组和
152-乘积最大子数组
300-最长递增子序列<vue3源码中快速diff算法又涉及到>
132-分割回文串 II
1143-最长公共子序列
718-最长重复子数组
213-打家劫舍 II
354-俄罗斯套娃信封问题
62-不同路径<递归超时>
63-不同路径 II
746-使用最小花费爬楼梯
91-解码方法<有意思>
322-零钱兑换