c
天地神仙
这个作者很懒,什么都没留下…
展开
-
do{...}while(0)的意义和用法
fun2();fun2();fun1;fun2();fun2;例如我们要在某个判断的地方使用这行代码实际上会被转化为fun2();此时不管condition是否生效,fun2都会执行,并不能达到我们的预期。如果我们在定义的时候加上大括号,像下面这样fun1();fun2();fun1();fun2();fun1;fun1();fun2();fun2;我们习惯性的会在函数后面加上分号,就像这样他实际会被转化为fun1();fun2();原创 2023-04-19 17:09:47 · 327 阅读 · 0 评论 -
LeetCode——278. 第一个错误的版本
一、题目你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有通过质量检测。由于每个版本都是基于之前的版本开发的,所以错误的版本之后的所有版本都是错的。假设你有 n 个版本 [1, 2, …, n],你想找出导致之后所有版本出错的第一个错误的版本。你可以通过调用 bool isBadVersion(version) 接口来判断版本号 version 是否在单元测试中出错。实现一个函数来查找第一个错误的版本。你应该尽量减少对调用 API 的次数。示例 1:输入:n = 5,原创 2022-02-09 21:43:01 · 129 阅读 · 0 评论 -
LeetCode——704. 二分查找
一、题目给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。示例 1:输入: nums = [-1,0,3,5,9,12], target = 9输出: 4解释: 9 出现在 nums 中并且下标为 4示例 2:输入: nums = [-1,0,3,5,9,12], target = 2输出: -1解释: 2 不存在 nums 中因此返回 -1来源:力扣(LeetCod原创 2022-02-09 21:27:46 · 873 阅读 · 0 评论 -
LeetCode——剑指 Offer 42. 连续子数组的最大和
一、题目输入一个整型数组,数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为O(n)。示例1:输入: nums = [-2,1,-3,4,-1,2,1,-5,4]输出: 6解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。提示:1 <= arr.length <= 10^5-100 <= arr[i] <= 100来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/li原创 2022-02-07 23:52:28 · 278 阅读 · 0 评论 -
LeetCode——剑指 Offer 52. 两个链表的第一个公共节点
一、题目输入两个链表,找出它们的第一个公共节点。如下面的两个链表**:**在节点 c1 开始相交。示例 1:输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB = 3输出:Reference of the node with value = 8输入解释:相交节点的值为 8 (注意,如果两个列表相交则不能为 0)。从各自的表头开始算起,链表 A 为 [4,1,8,4,5],链表 B原创 2022-01-20 13:27:10 · 92 阅读 · 0 评论 -
LeetCode——剑指 Offer 25. 合并两个排序的链表
一、题目输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。示例1:输入:1->2->4, 1->3->4输出:1->1->2->3->4->4来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/he-bing-liang-ge-pai-xu-de-lian-biao-lcof二、思路二路归并的思想,依次从两个链表中选出最小的节点加入新的链表,终止条件为一个链表为空。原创 2022-01-20 13:26:32 · 651 阅读 · 0 评论 -
LeetCode——剑指 Offer 22. 链表中倒数第k个节点
一、题目输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点。示例:给定一个链表: 1->2->3->4->5, 和 k = 2.返回链表 4->5.来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/lian-biao-z原创 2022-01-20 13:25:52 · 727 阅读 · 0 评论 -
LeetCode——剑指 Offer 18. 删除链表的节点
一、题目给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。注意:此题对比原题有改动示例 1:输入: head = [4,5,1,9], val = 5输出: [4,1,9]解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.示例 2:输入: head = [4,5,1,9], val = 1输出: [4,5,9]解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数原创 2022-01-20 13:24:47 · 132 阅读 · 0 评论 -
LeetCode——剑指 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]输出:true示例 2:输入:root原创 2022-01-19 23:55:30 · 86 阅读 · 0 评论 -
LeetCode——剑指 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]来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/er-cha-sh原创 2022-01-19 23:54:42 · 87 阅读 · 0 评论 -
LeetCode——剑指 Offer 26. 树的子结构
一、题目输入两棵二叉树A和B,判断B是不是A的子结构。(约定空树不是任意一个树的子结构)B是A的子结构, 即 A中有出现和B相同的结构和节点值。例如:给定的树 A: 3 / \ 4 5 / \ 1 2给定的树 B: 4 / 1返回 true,因为 B 与 A 的一个子树拥有相同的结构和节点值。示例 1:输入:A = [1,2,3], B = [3,1]输出:false示例 2:输入:A = [3,4,5,1,2], B = [原创 2022-01-19 23:53:56 · 72 阅读 · 0 评论 -
LeetCode——剑指 Offer 63. 股票的最大利润
一、题目假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖该股票一次可能获得的最大利润是多少?示例 1:输入: [7,1,5,3,6,4]输出: 5解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格。示例 2:输入: [7,6,4,3,1]输出: 0解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。来源:力扣(LeetCode)链原创 2022-01-18 20:05:37 · 101 阅读 · 0 评论 -
LeetCode——剑指 Offer 10- II. 青蛙跳台阶问题
一、题目一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。示例 1:输入:n = 2输出:2示例 2:输入:n = 7输出:21示例 3:输入:n = 0输出:1来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/qing-wa-tiao-tai-jie-wen-ti-lcof二、思原创 2022-01-18 19:54:04 · 232 阅读 · 0 评论 -
LeetCode——剑指 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输出:1示例 2:输入:n = 5输出:5原创 2022-01-18 19:53:29 · 200 阅读 · 0 评论 -
LeetCode——剑指 Offer 32 - III. 从上到下打印二叉树 III
一、题目此题和剑指 Offer 32 - I和剑指 Offer 32 - II为同类型的题目。可以先看前面的题目再来看这一题从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。例如:给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [20,9], [15,7]]二、思路大概思路查看上面提到的文章,在剑指 Offer 32 -原创 2022-01-17 16:54:38 · 534 阅读 · 0 评论 -
LeetCode——剑指 Offer 32 - II. 从上到下打印二叉树 II
一、题目此题和剑指 Offer 32 - I为同类型的题目。可以先看前面的题目再来看这一题从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。例如:给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [9,20], [15,7]]二、思路层次遍历,与上一个题目不同的是,这次要求输出的为二维数组,思路和上一个题目是一样的。这里采用原创 2022-01-17 16:50:25 · 601 阅读 · 0 评论 -
LeetCode——剑指 Offer 32 - I. 从上到下打印二叉树
一、题目从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。例如:给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回:[3,9,20,15,7]来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/cong-shang-dao-xia-da-yin-er-cha-shu-lcof二、思路这个就是二叉树的层序遍历。使用辅助队列,把根原创 2022-01-17 16:39:56 · 141 阅读 · 0 评论 -
LeetCode——剑指 Offer 50. 第一个只出现一次的字符
一、题目在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。示例 1:输入:s = “abaccdeff”输出:‘b’示例 2:输入:s = “”输出:’ ’来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/di-yi-ge-zhi-chu-xian-yi-ci-de-zi-fu-lcof二、思路定义一个大小为26的int型数组arr,用来统计每个字符出现的次数,第一次遍历字符串对数组进行赋值,原创 2022-01-13 22:12:37 · 109 阅读 · 0 评论 -
LeetCode——剑指 Offer 11. 旋转数组的最小数字
一、题目把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。给你一个可能存在 重复 元素值的数组 numbers ,它原来是一个升序排列的数组,并按上述情形进行了一次旋转。请返回旋转数组的最小元素。例如,数组 [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来源:力扣(LeetCode)链接:https://leetcode-cn.com/prob原创 2022-01-13 22:08:45 · 105 阅读 · 0 评论 -
LeetCode——剑指 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 <= 109来源:力扣(LeetCode)链接:https://原创 2022-01-12 21:47:49 · 182 阅读 · 0 评论 -
LeetCode——剑指 Offer 03. 数组中重复的数字
一、题目找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。示例 1:输入:[2, 3, 1, 0, 2, 5, 3]输出:2 或 3来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof二、思路题目中给的数组中所有原创 2022-01-12 21:24:45 · 272 阅读 · 0 评论 -
LeetCode——剑指 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来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/que-shi-de-shu-zi-lcof二、思原创 2022-01-12 17:00:26 · 264 阅读 · 0 评论 -
LeetCode——剑指 Offer 05. 替换空格
一、题目请实现一个函数,把字符串 s 中的每个空格替换成"%20"。示例 1:输入:s = “We are happy.”输出:“We%20are%20happy.”来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/ti-huan-kong-ge-lcof二、思路首先遍历一遍字符串,记录其中空格的数量,然后申请原来字符串长度+2*空格数量+1的空间(这里的1用来做字符串结尾的标志)记为arr然后把字符串复制到新申请的字符串中去,使用双指针原创 2022-01-12 00:44:52 · 99 阅读 · 0 评论 -
LeetCode——剑指 Offer 58 - II. 左旋转字符串
一、题目字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。示例 1:输入: s = “abcdefg”, k = 2输出: “cdefgab”示例 2:输入: s = “lrloseumgh”, k = 6输出: “umghlrlose”限制:1 <= k < s.length <= 10000来源:力扣(LeetCod原创 2022-01-12 00:20:49 · 123 阅读 · 0 评论 -
LeetCode——剑指 Offer 24. 反转链表
一、题目定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。示例:输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1->NULL限制:0 <= 节点个数 <= 5000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/fan-zhuan-lian-biao-lcof二、思路头插法构造一个虚拟头结点,从给定的头结点进原创 2022-01-10 21:44:32 · 492 阅读 · 0 评论 -
LeetCode——剑指 Offer 06. 从尾到头打印链表
一、题目输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。示例 1:输入:head = [1,3,2]输出:[2,3,1]限制:0 <= 链表长度 <= 10000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/cong-wei-dao-tou-da-yin-lian-biao-lcof二、思路最容易想到的一个方式就是先把链表逆置,然后顺序输出,我一开始也是这样写的,提交后发现时间和空间都不是很满意,后来原创 2022-01-10 20:49:09 · 277 阅读 · 0 评论 -
LeetCode——剑指 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.top(); --> 返回 0原创 2022-01-10 00:52:17 · 301 阅读 · 0 评论 -
LeetCode——89.格雷编码
一、题目n 位格雷码序列 是一个由 2n 个整数组成的序列,其中:每个整数都在范围 [0, 2n - 1] 内(含 0 和 2n - 1)第一个整数是 0一个整数在序列中出现 不超过一次每对 相邻 整数的二进制表示 恰好一位不同 ,且第一个 和 最后一个 整数的二进制表示 恰好一位不同给你一个整数 n ,返回任一有效的 n 位格雷码序列 。示例 1:输入:n = 2输出:[0,1,3,2]解释:[0,1,3,2] 的二进制表示是 [00,01,11,10] 。00 和 01 有一原创 2022-01-08 22:58:05 · 646 阅读 · 0 评论 -
c语言在输入和输出穿插使用遇到输出不显示的情况
在输出的语句后面加上fflush(stdout);原创 2021-08-25 09:40:37 · 412 阅读 · 0 评论