自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(30)
  • 收藏
  • 关注

原创 剑指 Offer 52. 两个链表的第一个公共节点

从各自的表头开始算起,链表 A 为 [4,1,8,4,5],链表 B 为 [5,0,1,8,4,5]。输入解释:相交节点的值为 2 (注意,如果两个列表相交则不能为 0)。输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB = 3。输入:intersectVal = 2, listA = [0,9,1,2,4], listB = [3,2,4], skipA = 3, skipB = 1。

2022-10-21 10:35:46 125

原创 剑指 Offer 25. 合并两个排序的链表

链接:https://leetcode.cn/problems/he-bing-liang-ge-pai-xu-de-lian-biao-lcof。输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。输入:1->2->4, 1->3->4。输出:1->1->2->3->4->4。0

2022-10-21 10:32:20 149

原创 剑指 Offer 22. 链表中倒数第k个节点

链接:https://leetcode.cn/problems/lian-biao-zhong-dao-shu-di-kge-jie-dian-lcof。例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点。输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。商业转载请联系官方授权,非商业转载请注明出处。给定一个链表: 1->2->3->4->5, 和 k = 2.

2022-10-21 10:30:27 105

原创 剑指 Offer 18. 删除链表的节点

链接:https://leetcode.cn/problems/shan-chu-lian-biao-de-jie-dian-lcof。解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9.输入: head = [4,5,1,9], val = 5。输入: head = [4,5,1,9], val = 1。输出: [4,1,9]

2022-10-21 10:28:41 109

原创 剑指 Offer 48. 最长不含重复字符的子字符串

链接:https://leetcode.cn/problems/zui-chang-bu-han-zhong-fu-zi-fu-de-zi-zi-fu-chuan-lcof。请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。输入: "abcabcbb"输入: "pwwkew"

2022-10-18 12:12:00 55

原创 剑指 Offer 46. 把数字翻译成字符串

python c++

2022-10-18 12:09:34 52

原创 剑指 Offer 26. 树的子结构

链接:https://leetcode.cn/problems/shu-de-zi-jie-gou-lcof。输入两棵二叉树A和B,判断B是不是A的子结构。(约定空树不是任意一个树的子结构)返回 true,因为 B 与 A 的一个子树拥有相同的结构和节点值。商业转载请联系官方授权,非商业转载请注明出处。输入:A = [3,4,5,1,2], B = [4,1]B是A的子结构, 即 A中有出现和B相同的结构和节点值。输入:A = [1,2,3], B = [3,1]来源:力扣(LeetCode)

2022-10-18 12:06:40 48

原创 剑指 Offer 47. 礼物的最大价值

在一个 m*n 的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于 0)。你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格、直到到达棋盘的右下角。给定一个棋盘及其上面的礼物的价值,请计算你最多能拿到多少价值的礼物?链接:https://leetcode.cn/problems/li-wu-de-zui-da-jie-zhi-lcof。商业转载请联系官方授权,非商业转载请注明出处。解释: 路径 1→3→5→2→1 可以拿到最多价值的礼物。来源:力扣(LeetCode)

2022-10-18 10:41:07 47

原创 剑指 Offer 42. 连续子数组的最大和

链接:https://leetcode.cn/problems/lian-xu-zi-shu-zu-de-zui-da-he-lcof。输入一个整型数组,数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。输入: nums = [-2,1,-3,4,-1,2,1,-5,4]著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。来源:力扣(LeetCode)要求时间复杂度为O(n)。

2022-10-18 10:38:58 65

原创 剑指 Offer 63. 股票的最大利润

解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5。链接:https://leetcode.cn/problems/gu-piao-de-zui-da-li-run-lcof。注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格。解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。输入: [7,1,5,3,6,4]0

2022-10-18 10:37:04 51

原创 剑指 Offer 10- II. 青蛙跳台阶问题

链接:https://leetcode.cn/problems/qing-wa-tiao-tai-jie-wen-ti-lcof。答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。来源:力扣(LeetCode)

2022-10-18 10:35:17 61

原创 剑指 Offer 10- I. 斐波那契数列

写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项(即 F(N))。链接:https://leetcode.cn/problems/fei-bo-na-qi-shu-lie-lcof。答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。斐波那契数列由 0 和 1 开始,之后的斐波那契数就是由之前的两数相加而得出。F(N) = F(N - 1) + F(N - 2), 其中 N > 1.来源:力扣(LeetCode)

2022-10-18 10:31:58 72

原创 剑指 Offer 28. 对称的二叉树

c++ python

2022-09-30 10:43:29 60

原创 剑指 Offer 27. 二叉树的镜像

链接:https://leetcode.cn/problems/er-cha-shu-de-jing-xiang-lcof。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。请完成一个函数,输入一个二叉树,该函数输出它的镜像。输入:root = [4,2,7,1,3,6,9]输出:[4,7,2,9,6,3,1]0

2022-09-30 10:40:59 51

原创 剑指 Offer 32 - I. 从上到下打印二叉树

链接:https://leetcode.cn/problems/cong-shang-dao-xia-da-yin-er-cha-shu-lcof。从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。给定二叉树: [3,9,20,null,null,15,7],来源:力扣(LeetCode)节点总数

2022-09-23 11:50:55 49

原创 剑指 Offer 32 - II. 从上到下打印二叉树 II

链接:https://leetcode.cn/problems/cong-shang-dao-xia-da-yin-er-cha-shu-ii-lcof。从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。给定二叉树: [3,9,20,null,null,15,7],来源:力扣(LeetCode)节点总数

2022-09-23 11:49:32 46

原创 剑指 Offer 32 - III. 从上到下打印二叉树 III

链接:https://leetcode.cn/problems/cong-shang-dao-xia-da-yin-er-cha-shu-iii-lcof。请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。给定二叉树: [3,9,20,null,null,15,7],来源:力扣(LeetCode)节点总数

2022-09-23 11:48:17 51

原创 剑指 Offer 50. 第一个只出现一次的字符 哈希表

链接:https://leetcode.cn/problems/di-yi-ge-zhi-chu-xian-yi-ci-de-zi-fu-lcof。在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。s 只包含小写字母。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。0

2022-09-22 16:06:46 376

原创 剑指 Offer 11. 旋转数组的最小数字 二分

给你一个可能存在 重复 元素值的数组 numbers ,它原来是一个升序排列的数组,并按上述情形进行了一次旋转。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一次旋转,该数组的最小值为 1。注意,数组 [a[0], a[1], a[2], ..., a[n-1]] 旋转一次 的结果为数组 [a[n-1], a[0], a[1], a[2], ..., a[n-2]]。著作权归领扣网络所有。输入:numbers = [3,4,5,1,2]输入:numbers = [2,2,2,0,1]

2022-09-22 16:05:10 49

原创 剑指 Offer 04. 二维数组中的查找

在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个高效的函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。链接:https://leetcode.cn/problems/er-wei-shu-zu-zhong-de-cha-zhao-lcof。商业转载请联系官方授权,非商业转载请注明出处。给定 target = 20,返回 false。给定 target = 5,返回 true。来源:力扣(LeetCode)

2022-09-22 16:02:52 762

原创 剑指 Offer 35. 复杂链表的复制

在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。输入:head = [[7,null],[13,0],[11,4],[10,2],[1,0]]输出:[[7,null],[13,0],[11,4],[10,2],[1,0]]输入:head = [[3,null],[3,0],[3,null]]输出:[[3,null],[3,0],[3,null]]输入:head = [[1,1],[2,1]]输出:[[1,1],[2,1]]

2022-09-21 16:42:32 59

原创 剑指 Offer 03. 数组中重复的数字

在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。链接:https://leetcode.cn/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。来源:力扣(LeetCode)找出数组中重复的数字。

2022-09-21 14:54:22 58

原创 剑指 Offer 53 - I. 在排序数组中查找数字 I

链接:https://leetcode.cn/problems/zai-pai-xu-shu-zu-zhong-cha-zhao-shu-zi-lcof。输入: nums = [5,7,7,8,8,10], target = 8。输入: nums = [5,7,7,8,8,10], target = 6。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。统计一个数字在排序数组中出现的次数。来源:力扣(LeetCode)nums 是一个非递减数组。

2022-09-21 14:52:38 244

原创 剑指 Offer 53 - II. 0~n-1中缺失的数字

一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1之内。在范围0~n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字。链接:https://leetcode.cn/problems/que-shi-de-shu-zi-lcof。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。输入: [0,1,2,3,4,5,6,7,9]1

2022-09-21 14:50:24 43

原创 剑指 Offer 58 - II. 左旋转字符串

字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。链接:https://leetcode.cn/problems/zuo-xuan-zhuan-zi-fu-chuan-lcof。输入: s = "lrloseumgh", k = 6。输入: s = "abcdefg", k = 2。输出: "umghlrlose"输出: "cdefgab"

2022-09-21 10:36:19 46

原创 剑指 Offer 05. 替换空格

链接:https://leetcode.cn/problems/ti-huan-kong-ge-lcof。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。请实现一个函数,把字符串 s 中的每个空格替换成"%20"。输入:s = "We are happy."输出:"We%20are%20happy."0

2022-09-21 10:34:27 234

原创 leetcode 剑指 Offer 24. 反转链表

链接:https://leetcode.cn/problems/fan-zhuan-lian-biao-lcof。定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。输入: 1->2->3->4->5->NULL。输出: 5->4->3->2->1->NULL。0

2022-09-14 16:30:48 113

原创 leetcode 剑指 Offer 06. 从尾到头打印链表

输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。0

2022-09-14 16:28:53 100

原创 leetcode剑指 Offer 30. 包含min函数的栈

定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。--> 返回 -3.minStack.min();--> 返回 -2.各函数的调用总次数不超过 20000 次。

2022-09-06 22:12:22 395

原创 leetcode剑指 Offer 09. 用两个栈实现队列

用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )最多会对 appendTail、deleteHead 进行 10000 次C++输出:[null,-1,null,null,5,2]输出:[null,null,3,-1]

2022-09-06 22:09:32 99

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除