自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

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

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

链接:https://leetcode.cn/problems/gu-piao-de-zui-da-li-run-lcof题目: 假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖该股票一次可能获得的最大利润是多少?示例 1:输入: [7,1,5,3,6,4]输出: 5解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。 注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格。示例 2:输入: [7,6

2022-05-31 20:39:28 142 1

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

链接:https://leetcode.cn/problems/qing-wa-tiao-tai-jie-wen-ti-lcof题目:一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。示例 1:输入:n = 2输出:2示例 2:输入:n = 7输出:21示例 3:输入:n = 0输出:1思路:其实就是一个斐波那契数列

2022-05-31 20:34:31 133

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

链接:https://leetcode.cn/problems/fei-bo-na-qi-shu-lie-lcof题目:写一个函数,输入 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),如计算初始结果...

2022-05-31 20:01:18 131

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

链接:https://leetcode.cn/problems/dui-cheng-de-er-cha-shu-lcof请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。例如,二叉树 [1,2,2,3,4,4,3] 是对称的。1/ \2 2/ \ / \3 4 4 3但是下面这个[1,2,2,null,3,null,3] 则不是镜像对称的:1/ \2 2 \ ...

2022-05-30 21:56:24 1127

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

链接:https://leetcode.cn/problems/er-cha-shu-de-jing-xiang-lcof请完成一个函数,输入一个二叉树,该函数输出它的镜像。例如输入:4/ \2 7/ \ / \1 3 6 9镜像输出: 4/ \7 2/ \ / \9 6 31示例 1:输入:root = [4,2,7,1,3,6,9]输出:[4...

2022-05-30 21:54:36 80

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

链接:https://leetcode.cn/problems/shu-de-zi-jie-gou-lcof输入两棵二叉树A和B,判断B是不是A的子结构。(约定空树不是任意一个树的子结构)B是A的子结构, 即 A中有出现和B相同的结构和节点值。例如:给定的树 A:3/ \4 5/ \1 2给定的树 B:4/1返回 true,因为 B 与 A 的一个子树拥有相同的结构和节点值。示例 1:输入:A = [1,2...

2022-05-30 21:52:33 53

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

链接:https://leetcode.cn/problems/cong-shang-dao-xia-da-yin-er-cha-shu-iii-lcof题目:请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3...

2022-05-25 18:01:05 101

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

链接:https://leetcode.cn/problems/cong-shang-dao-xia-da-yin-er-cha-shu-ii-lcof题目描述:从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [9,20], [15,7]]/** * Def...

2022-05-25 17:58:04 68

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

链接:https://leetcode.cn/problems/cong-shang-dao-xia-da-yin-er-cha-shu-lcof题目描述:从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回:[3,9,20,15,7]代码:class Solution {public: vect...

2022-05-25 17:50:31 82

原创 剑指 Offer 50. 第一个只出现一次的字符 【day5】

链接:https://leetcode.cn/problems/di-yi-ge-zhi-chu-xian-yi-ci-de-zi-fu-lcof题目: 在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。示例 1:输入:s = "abaccdeff"输出:'b'示例 2:输入:s = ""输出:' '解题思路:借助map容器的记录词频,统计字符出现次数,遇到一次的字符,直接返回。代码:class Solution {publi.

2022-05-24 14:19:36 65

原创 剑指 Offer 11. 旋转数组的最小数字 【day5】

链接:https://leetcode.cn/problems/xuan-zhuan-shu-zu-de-zui-xiao-shu-zi-lcof题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 给你一个可能存在重复元素值的数组numbers,它原来是一个升序排列的数组,并按上述情形进行了一次旋转。请返回旋转数组的最小元素。例如,数组[3,4,5,1,2] 为 [1,2,3,4,5] 的一次旋转,该数组的最小值为 1。注意,数组 [a[0], a...

2022-05-24 14:17:10 93 2

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

链接:https://leetcode.cn/problems/er-wei-shu-zu-zhong-de-cha-zhao-lcof题目描述:在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个高效的函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。示例:现有矩阵 matrix 如下:[ [1, 4, 7, 11, 15], [2, 5, 8, 12, 19], [3, 6, 9...

2022-05-24 14:15:04 106

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

链接:https://leetcode.cn/problems/que-shi-de-shu-zi-lcof一个长度为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解题思路:因为题目中说是从0开始的,所以直接对比下标和值是否一样就可以。class Soluti

2022-05-24 13:49:33 67

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

链接:https://leetcode.cn/problems/zai-pai-xu-shu-zu-zhong-cha-zhao-shu-zi-lcof统计一个数字在排序数组中出现的次数。示例 1:输入: nums = [5,7,7,8,8,10], target = 8输出: 2示例2:输入: nums = [5,7,7,8,8,10], target = 6输出: 0解题思路:直接暴力求解了。。。其实最好用二分法,暴力很有可能超时。class Solution {pu.

2022-05-24 13:47:04 70

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

链接:https://leetcode.cn/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。示例 1:输入:[2, 3, 1, 0, 2, 5, 3]输出:2 或 3解题思路:一:我首先想到的是暴力法,但是时间复杂度太高了,会超时。.

2022-05-24 13:44:09 1000

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

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

2022-05-23 15:19:30 66

原创 剑指 Offer 05. 替换空格 【day3】

链接:https://leetcode.cn/problems/ti-huan-kong-ge-lcof题目:请实现一个函数,把字符串 s 中的每个空格替换成"%20"。示例 1:输入:s = "We are happy."输出:"We%20are%20happy."方法一:创建一个新字符串class Solution {public: string replaceSpace(string s) { string ans; for(int i

2022-05-23 13:40:27 80

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

链接:力扣题目:请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。示例:思路:第一步:复制节点例在A、B节点中间插入一个节点A',类似的创建B'、C' 。然后A -> A' -> B -> B' -> C -> C' -> NULL 连接起来。random同样复制,比如A -> random = C可以复

2022-05-21 21:32:22 65

原创 剑指 Offer 24. 反转链表 【day2】

链接:力扣题目:定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。示例:输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1->NULL解题思路:分别创建节点curr、prev、nextcurr:当前的节点prev:当前节点的上一个,初始化为空。next:当前节点的下一个将curr的下一个节点设置为prev,实现反转。再将prev和curr同时往前移。代码

2022-05-21 21:10:43 122

原创 剑指 Offer 06. 从尾到头打印链表 【day2】

链接:力扣题目:输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。示例 1:输入:head = [1,3,2] 输出:[2,3,1]解题思路:因为是从尾到头打印,我们可以利用栈先进后出的性质,把每个节点放入一个栈中。又因为题目需要数组来输出,所以创建一个vector,将栈顶元素放入vector里,最后返回这个vector。代码:/** * Definition for singly-linked list. * struct ListNode { * ..

2022-05-21 20:54:14 166

原创 剑指 Offer 30. 包含min函数的栈 【day1】

链接:https://leetcode.cn/problems/bao-han-minhan-shu-de-zhan-lcof题目描述:定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。示例:解题思路:创建两个栈:stk和min_stkstk:把所有元素都放入这个栈中。min_stk:把入栈过程中,最小元素放入这个栈中。代码:class MinStack {public:

2022-05-20 18:28:41 115

原创 剑指 Offer 09. 用两个栈实现队列栈设计队列【day1】

链接:https://leetcode.cn/problems/yong-liang-ge-zhan-shi-xian-dui-lie-lcof题目描述:用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )示例:思路:栈:先进后出 (可以理解为杯子)队列:先进先出(可以理解为管道)创建两个栈:inStack.

2022-05-20 18:05:13 99

原创 同一进程下的线程可以共享什么?

同一进程下的线程可以共享(A)A. data sectionB. register setC. thread IDD. stack分析:线程共享的内容包括:进程代码段进程的公有数据(利用这些共享的数据,线程很容易的实现相互之间的通讯)进程打开的文件描述符信号的处理器进程的当前目录和进程用户ID与进程组ID 线程独有的内容包括(个性):线程ID寄存器组的值线程的堆栈错误返回码线程的信号屏蔽码...

2022-03-23 09:48:29 657 1

原创 C++构造函数、析构函数及其调用顺序详解

构造函数:定义:是特殊的成员函数,需要注意的是,构造函数的虽然名称叫构造,但是需要注意的是构造函数的主要任务并不是开空间创建对象,而是初始化对象。特点:函数名与类名相同。 无返回值。 对象实

2022-03-15 16:38:08 1868 5

原创 1.this指针存在哪里?2.this指针可以为空吗

1.this指针存在哪里?其实编译器在生成程序时加入了获取对象首地址的相关代码。并把获取的首地址存放在了寄存器ECX中(VC++编译器是放在ECX中,其它编译器有可能不同)。也就是成员函数的其它参数正常都是存放在栈中。而this指针参数则是存放在寄存器中。类的静态成员函数因为没有this指针这个参数,所以类的静态成员函数也就无法调用类的非静态成员变量。2.this指针可以为空吗?List item可以为空,当我们在调用函数的时候,如果函数内部并不需要使用到this,也就是不需要通过this指向当

2022-03-07 21:17:58 614

原创 c++函数重载

函数重载: c++在 同一作用域中 声明的同名函数,这些函数的 形参列表(参数个数 或 类型 或 顺序)必须不同。C语言中为什么不能支持函数重载?因为C的编译器,直接使用函数名进行关联。在函数名相同的时候,就没办法区分了。C++为什么支持函数重载?因为函数名的修饰规则:不能直接使用函数名,而是要对函数名进行修饰,需要带入参数特点来修饰。所以,函数名相同,只要参数不同,那就可以区分,就支持重载。C++中不能重载的运算符?有5个,分别为:(1)?: (2) . (3)

2022-03-03 15:22:02 403

空空如也

空空如也

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

TA关注的人

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