leetcode力扣
Smoothzjc
SCAU 希望在CSDN上结识到更多志同道合的人!
展开
-
100. 相同的树 Javascript递归解法
递归解决,什么时候才返回false,左右子树不相等,或递归中的p和q根结点的值不相同时,其他情况都是true原创 2022-01-13 22:57:03 · 525 阅读 · 0 评论 -
剑指 Offer II 044. 二叉树每层的最大值 Javascript解法
层序遍历的思路,只不过不用新建一个临时数组存储每一层的全部变量,而是逐一比较大小,压入最大值即可原创 2022-01-13 22:23:34 · 443 阅读 · 0 评论 -
剑指 Offer II 031. 最近最少使用缓存 Javascript解法Map
Map数据结构 + 队列先进先出思想,最少使用往队头靠,最常使用往队尾靠原创 2022-01-12 23:53:43 · 340 阅读 · 0 评论 -
344. 反转字符串 Javascript一行代码解法
344. 反转字符串难度:简单编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。示例 1:输入:s = [“h”,“e”,“l”,“l”,“o”]输出:[“o”,“l”,“l”,“e”,“h”]示例 2:输入:s = [“H”,“a”,“n”,“n”,“a”,“h”]输出:[“h”,“a”,“n”,“n”,“a”,“H”]提示:1 <= s.lengt原创 2022-01-12 22:40:27 · 122 阅读 · 0 评论 -
912. 排序数组 Javascript快速排序解法
快速排序原创 2022-01-12 22:30:06 · 173 阅读 · 0 评论 -
106. 从中序与后序遍历序列构造二叉树 Javascript解法
后序遍历最后一位为根节点,中序中找下标,根据下标分割成左右子数组,继续递归原创 2022-01-12 19:23:52 · 363 阅读 · 0 评论 -
剑指 Offer 07. 重建二叉树 Javascript解法
前序遍历第一位,中序中找下标,根据下标分割成左右子数组,继续递归原创 2022-01-12 18:55:43 · 252 阅读 · 0 评论 -
107. 二叉树的层序遍历 II Javascript解法
107. 二叉树的层序遍历 II难度:中等给你二叉树的根节点 root ,返回其节点值 自底向上的层序遍历 。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)示例 1:输入:root = [3,9,20,null,null,15,7]输出:[[15,7],[9,20],[3]]示例 2:输入:root = [1]输出:[[1]]示例 3:输入:root = []输出:[]提示:树中节点数目在范围 [0, 2000] 内-1000 <= Node.val <原创 2022-01-12 18:34:43 · 109 阅读 · 0 评论 -
剑指 Offer II 022. 链表中环的入口节点
链表是否有环?如何查找链表中环的入口结点?该文章会一一为你详细道来原创 2022-01-12 18:15:41 · 104 阅读 · 0 评论 -
剑指 Offer II 072. 求平方根 javascript解法
剑指 Offer II 072. 求平方根简单给定一个非负整数 x ,计算并返回 x 的平方根,即实现 int sqrt(int x) 函数。正数的平方根有两个,只输出其中的正数平方根。如果平方根不是整数,输出只保留整数的部分,小数部分将被舍去。示例 1:输入: x = 4输出: 2示例 2:输入: x = 8输出: 2解释: 8 的平方根是 2.82842…,由于小数部分将被舍去,所以返回 2提示:0 <= x <= 2^31 - 1分析该解法思维较简单,向下取整的原创 2022-01-12 17:29:42 · 181 阅读 · 0 评论 -
剑指 Offer 28. 对称的二叉树 javascript解法
⚡️剑指 Offer 28. 对称的二叉树⚡️请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。例如,二叉树 [1,2,2,3,4,4,3] 是对称的。 1 / \ 2 2 / \ / \3 4 4 3但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的: 1 / \ 2 2 \ \ 3 3示例 1:输入:root = [1,2,2,3,4,4,3]输原创 2021-11-06 16:37:30 · 117 阅读 · 0 评论 -
剑指 Offer 27. 二叉树的镜像 javascript解法
⚡️剑指 Offer 27. 二叉树的镜像⚡️请完成一个函数,输入一个二叉树,该函数输出它的镜像。例如输入: 4 / \ 2 7 / \ / \1 3 6 9镜像输出: 4 / \ 7 2 / \ / \9 6 3 1示例 1:输入:root = [4,2,7,1,3,6,9]输出:[4,7,2,9,6,3,1]限制:0 <= 节点个数 <= 1000⚡️分析⚡️递归,先左右原创 2021-11-06 15:48:58 · 449 阅读 · 0 评论 -
剑指 Offer 32 - III. 从上到下打印二叉树 III(medium) javascript解法
⚡️剑指 Offer 32 - III. 从上到下打印二叉树 III⚡️请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。例如:给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [20,9], [15,7]]提示:节点总数 <= 1000⚡️分析原创 2021-11-06 15:05:57 · 402 阅读 · 0 评论 -
剑指 Offer 32 - II. 从上到下打印二叉树 II javascript解法
⚡️剑指 Offer 32 - II. 从上到下打印二叉树 II⚡️从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。例如:给定二叉树: [3,9,20,null,null,15,7],3/ 9 20/ 15 7返回其层次遍历结果:[[3],[9,20],[15,7]]提示:节点总数 <= 1000⚡️分析⚡️数组嵌套数组,内层数组为每一层的总结点数思路:也是用队列来解决,先判断此时队列长度(每一层的结点个数),然后通过for原创 2021-10-24 15:44:43 · 126 阅读 · 0 评论 -
剑指 Offer 32 - I. 从上到下打印二叉树(medium) javascript解法
⚡️剑指 Offer 32 - I. 从上到下打印二叉树⚡️从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。例如:给定二叉树: [3,9,20,null,null,15,7],3/ 9 20/ 15 7返回:[3,9,20,15,7]提示:节点总数 <= 1000⚡️分析⚡️从上到下、从左到右打印二叉树,思路可以是通过一个队列来求解。当队列中有元素时,将队头移出,如果该结点有左或右结点那就压入队列即可代码如下:/** * Defini原创 2021-10-24 15:24:54 · 1866 阅读 · 0 评论 -
剑指 Offer 50. 第一个只出现一次的字符 99.92%的javascript解法
⚡️剑指 Offer 50. 第一个只出现一次的字符⚡️在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。示例 1:输入:s = “abaccdeff”输出:‘b’示例 2:输入:s = “”输出:’ ’限制:0 <= s 的长度 <= 50000⚡️分析⚡️记一次时间复杂度差点100%通过两次indexOf的api来查询是否有重复的字母出现即可,如果第二次是-1那就没,如果是别的数字那就有重复的代码如下:/** * @p原创 2021-10-20 13:09:41 · 77 阅读 · 0 评论 -
剑指 Offer 11. 旋转数组的最小数字 javascript解法
⚡️剑指 Offer 11. 旋转数组的最小数字⚡️把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一个旋转,该数组的最小值为1。示例 1:输入:[3,4,5,1,2]输出:1示例 2:输入:[2,2,2,0,1]输出:0⚡️分析⚡️返回用sort排序后数组的第一位即可代码如下:/** * @param {number[]} numbers原创 2021-10-20 12:51:22 · 105 阅读 · 0 评论 -
剑指 Offer 04. 二维数组中的查找(medium) javascript解法
⚡️剑指 Offer 04. 二维数组中的查找⚡️在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个高效的函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。示例:现有矩阵 matrix 如下:[[1, 4, 7, 11, 15],[2, 5, 8, 12, 19],[3, 6, 9, 16, 22],[10, 13, 14, 17, 24],[18, 21, 23, 26, 30]]给定原创 2021-10-20 12:37:11 · 109 阅读 · 0 评论 -
剑指 Offer 53 - II. 0~n-1中缺失的数字 javascript解法
⚡️剑指 Offer 53 - II. 0~n-1中缺失的数字⚡️一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1之内。在范围0~n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字。示例 1:输入: [0,1,3]输出: 2示例 2:输入: [0,1,2,3,4,5,6,7,9]输出: 8限制:1 <= 数组长度 <= 10000⚡️分析⚡️既然是递增排序数组,且有且只有一个数字不在,那么可以通过判断前后数字是不是相差1来原创 2021-10-19 13:26:53 · 134 阅读 · 1 评论 -
剑指 Offer 53 - I. 在排序数组中查找数字 I javascript解法
⚡️剑指 Offer 53 - I. 在排序数组中查找数字 I⚡️统计一个数字在排序数组中出现的次数。示例 1:输入: nums = [5,7,7,8,8,10], target = 8输出: 2示例 2:输入: nums = [5,7,7,8,8,10], target = 6输出: 0提示:0 <= nums.length <= 105-109 <= nums[i] <= 109nums 是一个非递减数组-109 <= target <= 10原创 2021-10-19 13:17:07 · 172 阅读 · 0 评论 -
剑指 Offer 03. 数组中重复的数字 javascript解法
剑指 Offer 03. 数组中重复的数字找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。示例 1:输入:[2, 3, 1, 0, 2, 5, 3]输出:2 或 3限制:2 <= n <= 100000⚡️分析⚡️由于题目有限制:所有数字都在 0~n-1 的范围内。因此用空数组进行打表计数即可,用时间换空间代码如下原创 2021-10-19 13:06:32 · 133 阅读 · 0 评论 -
剑指 Offer 58 - II. 左旋转字符串 javascript解法
⚡️剑指 Offer 58 - II. 左旋转字符串⚡️字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。示例 1:输入: s = “abcdefg”, k = 2输出: “cdefgab”示例 2:输入: s = “lrloseumgh”, k = 6输出: “umghlrlose”限制:1 <= k < s.length &原创 2021-10-18 09:18:51 · 272 阅读 · 0 评论 -
剑指 Offer 05. 替换空格 javascript解法
⚡️剑指 Offer 05. 替换空格⚡️请实现一个函数,把字符串 s 中的每个空格替换成"%20"。示例 1:输入:s = “We are happy.”输出:“We%20are%20happy.”限制:0 <= s 的长度 <= 10000⚡️分析⚡️用正则表达式全局替换所有空格为%20即可代码如下:/** * @param {string} s * @return {string} */var replaceSpace = function(s) {原创 2021-10-18 09:11:20 · 213 阅读 · 0 评论 -
剑指 Offer 35. 复杂链表的复制(medium) javascript解法
⚡️剑指 Offer 35. 复杂链表的复制⚡️请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。示例 1:输入:head = [[7,null],[13,0],[11,4],[10,2],[1,0]]输出:[[7,null],[13,0],[11,4],[10,2],[1,0]]示例 2:输入:head = [[1,1],[2,1]]输出:[[1,1],原创 2021-10-17 13:00:38 · 92 阅读 · 0 评论 -
剑指 Offer 24. 反转链表 javascript解法
⚡️剑指 Offer 24. 反转链表⚡️定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。示例:输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1->NULL限制:0 <= 节点个数 <= 5000⚡️分析⚡️用三个指针解决。第一个指针tail是翻转后的头部,第二个和第三个指针为原链表的当前结点和下一结点。先让原链表第一个指针等于tail然后.next = nu原创 2021-10-17 10:01:16 · 169 阅读 · 0 评论 -
剑指 Offer 06. 从尾到头打印链表 javascript解法
⚡️剑指 Offer 06. 从尾到头打印链表⚡️输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。示例 1:输入:head = [1,3,2]输出:[2,3,1]限制:0 <= 链表长度 <= 10000⚡️分析⚡️对于链表各元素,从头压入数组,然后返回翻转后的数组即可代码如下:/** * Definition for singly-linked list. * function ListNode(val) { * this.val = v原创 2021-10-17 09:44:51 · 270 阅读 · 1 评论 -
剑指 Offer 09. 用两个栈实现队列 javascript解法
⚡️剑指 Offer 09. 用两个栈实现队列⚡️用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )示例 1:输入:[“CQueue”,“appendTail”,“deleteHead”,“deleteHead”][[],[3],[],[]]输出:[null,null,3,-1]示例 2:输入:[“CQueue”,“de原创 2021-10-17 09:29:11 · 104 阅读 · 0 评论 -
剑指 Offer 30. 包含min函数的栈 javascript解法
⚡️剑指 Offer 30. 包含min函数的栈⚡️定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。示例:MinStack minStack = new MinStack();minStack.push(-2);minStack.push(0);minStack.push(-3);minStack.min(); --> 返回 -3.minStack.pop();minStack.t原创 2021-10-17 09:37:52 · 114 阅读 · 0 评论 -
69. x 的平方根 -力扣(leetCode)Javascript(要时刻牢记js的除号没有自动取整功能)
⚡️69. x 的平方根⚡️给你一个非负整数 x ,计算并返回 x 的 平方根 。由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。示例 1:输入:x = 4输出:2示例 2:输入:x = 8输出:2解释:8 的平方根是 2.82842…, 由于返回类型是整数,小数部分将被舍去。提示:0 <= x <= 231 - 1⚡️分析⚡️通过二分查找缩小范围即可,原创 2021-09-16 20:23:43 · 157 阅读 · 0 评论 -
110. 平衡二叉树 -力扣(leetCode)JS解法
⚡️110. 平衡二叉树⚡️给定一个二叉树,判断它是否是高度平衡的二叉树。本题中,一棵高度平衡二叉树定义为:一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。示例 1:输入:root = [3,9,20,null,null,15,7]输出:true示例 2:输入:root = [1,2,2,3,3,null,null,4,4]输出:false示例 3:输入:root = []输出:true提示:树中的节点数在范围 [0, 5000] 内-104 <= No原创 2021-09-14 22:58:46 · 234 阅读 · 0 评论 -
509. 斐波那契数 -力扣(leetCode)JS解法
⚡️509. 斐波那契数⚡️斐波那契数,通常用 F(n) 表示,形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:F(0) = 0,F(1) = 1F(n) = F(n - 1) + F(n - 2),其中 n > 1给你 n ,请计算 F(n) 。示例 1:输入:2输出:1解释:F(2) = F(1) + F(0) = 1 + 0 = 1示例 2:输入:3输出:2解释:F(3) = F(2) + F(1) = 1 + 1原创 2021-09-09 00:11:08 · 162 阅读 · 0 评论 -
19. 删除链表的倒数第 N 个结点(medium) -力扣(leetCode)JS解法
⚡️19. 删除链表的倒数第 N 个结点⚡️给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。进阶:你能尝试使用一趟扫描实现吗?示例 1:输入:head = [1,2,3,4,5], n = 2输出:[1,2,3,5]示例 2:输入:head = [1], n = 1输出:[]示例 3:输入:head = [1,2], n = 1输出:[1]提示:链表中结点的数目为 sz1 <= sz <= 300 <= Node.val <= 100原创 2021-09-06 09:14:23 · 88 阅读 · 0 评论 -
226. 翻转二叉树 -力扣(leetCode)JS迭代和分而治之两种解法
⚡️226. 翻转二叉树⚡️翻转一棵二叉树。示例:输入: 4/ 2 7/ \ / 1 3 6 9输出: 4/ 7 2/ \ / 9 6 3 1备注:这个问题是受到 Max Howell 的 原问题 启发的 :谷歌:我们90%的工程师使用您编写的软件(Homebrew),但是您却无法在面试时在白板上写出翻转二叉树这道题,这太糟糕了。⚡️分析⚡️1.迭代将左右翻转即可2.分而治之思想来递归1.迭代代码如下:/*原创 2021-09-05 08:56:54 · 161 阅读 · 1 评论 -
145. 二叉树的后序遍历 -力扣(leetCode)JS非递归解法
⚡️145. 二叉树的后序遍历⚡️给定一个二叉树,返回它的 后序 遍历。示例:输入: [1,null,2,3]12/3输出: [3,2,1]进阶: 递归算法很简单,你可以通过迭代算法完成吗?⚡️分析⚡️用栈结构特性先进先出来解决,先压根节点,然后左,右,接着链表全部压入后;新建第二个栈,进行压入弹出。例如:[1,2,3],先压入1到queue里,然后2,3分别压入栈,此时第一个栈为[2,3],接着3和2相继弹出压入queue,此时queue:[1,3,2],接着再将queue依次原创 2021-09-05 08:50:00 · 154 阅读 · 0 评论 -
144. 二叉树的前序遍历 -力扣(leetCode)JS解法
⚡️144. 二叉树的前序遍历⚡️给你二叉树的根节点 root ,返回它节点值的 前序 遍历。示例 1:输入:root = [1,null,2,3]输出:[1,2,3]示例 2:输入:root = []输出:[]示例 3:输入:root = [1]输出:[1]示例 4:输入:root = [1,2]输出:[1,2]示例 5:输入:root = [1,null,2]输出:[1,2]提示:树中节点数目在范围 [0, 100] 内-100 <= Node.val <原创 2021-09-05 08:09:53 · 242 阅读 · 0 评论 -
剑指 Offer 10- I. 斐波那契数列 -力扣(leetCode)JS解法
⚡️剑指 Offer 10- I. 斐波那契数列⚡️写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项(即 F(N))。斐波那契数列的定义如下:F(0) = 0, F(1) = 1F(N) = F(N - 1) + F(N - 2), 其中 N > 1.斐波那契数列由 0 和 1 开始,之后的斐波那契数就是由之前的两数相加而得出。答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。示例 1:输入:n = 2输出原创 2021-09-04 20:42:00 · 158 阅读 · 0 评论 -
剑指 Offer 22. 链表中倒数第k个节点 -力扣(leetCode)JS解法
⚡️剑指 Offer 22. 链表中倒数第k个节点⚡️输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点。示例:给定一个链表: 1->2->3->4->5, 和 k = 2.返回链表 4->5.⚡️分析⚡️先遍历一次看看总共有sum个结点,再p指针回到链表头部,每次往后原创 2021-09-04 20:05:21 · 188 阅读 · 0 评论 -
374. 猜数字大小 -力扣(leetCode)JS二分
⚡️374. 猜数字大小⚡️猜数字游戏的规则如下:每轮游戏,我都会从 1 到 n 随机选择一个数字。 请你猜选出的是哪个数字。如果你猜错了,我会告诉你,你猜测的数字比我选出的数字是大了还是小了。你可以通过调用一个预先定义好的接口 int guess(int num) 来获取猜测结果,返回值一共有 3 种可能的情况(-1,1 或 0):-1:我选出的数字比你猜的数字小 pick < num1:我选出的数字比你猜的数字大 pick > num0:我选出的数字和你猜的数字一样。恭喜!你猜原创 2021-08-28 08:20:47 · 233 阅读 · 0 评论 -
23. 合并K个升序链表(hard) -力扣(leetCode)JS小根堆
⚡️23. 合并K个升序链表⚡️给你一个链表数组,每个链表都已经按升序排列。请你将所有链表合并到一个升序链表中,返回合并后的链表。示例 1:输入:lists = [[1,4,5],[1,3,4],[2,6]]输出:[1,1,2,3,4,4,5,6]解释:链表数组如下:[1->4->5,1->3->4,2->6]将它们合并到一个有序链表中得到。1->1->2->3->4->4->5->6示例 2:输入:lis原创 2021-08-21 10:14:28 · 245 阅读 · 0 评论 -
347. 前 K 个高频元素(medium) -力扣(leetCode)JS小根堆
⚡️347. 前 K 个高频元素⚡️给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。示例 1:输入: nums = [1,1,1,2,2,3], k = 2输出: [1,2]示例 2:输入: nums = [1], k = 1输出: [1]提示:1 <= nums.length <= 105k 的取值范围是 [1, 数组中不相同的元素的个数]题目数据保证答案唯一,换句话说,数组中前 k 个高频元素的集合是唯一原创 2021-08-21 08:45:54 · 160 阅读 · 0 评论