自定义博客皮肤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)
  • 收藏
  • 关注

原创 leetcode 101. 对称二叉树

leetcode 101. 对称二叉树题目详情题目链接给定一个二叉树,检查它是否是镜像对称的。例如,二叉树 [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进阶:你可以运用递归和迭代两种方法解决这个问题吗?我的代码class Solution {private: vector<TreeNode

2020-05-31 23:01:52 87

原创 leetcode 84. 柱状图中最大的矩形

leetcode 84. 柱状图中最大的矩形题目详情题目链接给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。求在该柱状图中,能够勾勒出来的矩形的最大面积。以上是柱状图的示例,其中每个柱子的宽度为 1,给定的高度为 [2,1,5,6,2,3]。图中阴影部分为所能勾勒出的最大矩形面积,其面积为 10 个单位。示例:输入: [2,1,5,6,2,3]输出: 10我的代码class Solution {private: int re

2020-05-30 23:47:37 84

原创 leetcode 198. 打家劫舍

leetcode 198. 打家劫舍题目详情题目链接你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。示例 1:输入: [1,2,3,1]输出: 4解释: 偷窃 1 号房屋 (金额 = 1) ,然后偷窃 3 号房屋 (金额 = 3)。偷窃到的最高金

2020-05-29 21:47:56 75

原创 leetcode 394. 字符串解码

leetcode 394. 字符串解码题目详情题目链接给定一个经过编码的字符串,返回它解码后的字符串。编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k ,例如不会出现像 3a 或 2[4] 的输入。示例:s = “3[a]2[bc]”,

2020-05-28 23:51:30 182

原创 leetcode 974. 和可被 K 整除的子数组

leetcode 974. 和可被 K 整除的子数组题目详情题目链接给定一个整数数组 A,返回其中元素之和可被 K 整除的(连续、非空)子数组的数目。示例:输入:A = [4,5,0,-2,-3,1], K = 5输出:7解释:有 7 个子数组满足其元素之和可被 K = 5 整除:[4, 5, 0, -2, -3, 1], [5], [5, 0], [5, 0, -2, -3], [0], [0, -2, -3], [-2, -3]提示:1 <= A.length &lt

2020-05-27 21:58:02 133

原创 leetcode 287. 寻找重复数

leetcode 287. 寻找重复数题目详情题目链接给定一个包含 n + 1 个整数的数组 nums,其数字都在 1 到 n 之间(包括 1 和 n),可知至少存在一个重复的整数。假设只有一个重复的整数,找出这个重复的数。示例 1:输入: [1,3,4,2,2]输出: 2示例 2:输入: [3,1,3,4,2]输出: 3说明:不能更改原数组(假设数组是只读的)。只能使用额外的 O(1) 的空间。时间复杂度小于 O(n2) 。数组中只有一个重复的数字,但它可能不止重复出现

2020-05-26 21:53:31 217 1

原创 leetcode 146. LRU缓存机制

leetcode 146. LRU缓存机制题目详情题目链接运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制。它应该支持以下操作: 获取数据 get 和 写入数据 put 。获取数据 get(key) - 如果密钥 (key) 存在于缓存中,则获取密钥的值(总是正数),否则返回 -1。写入数据 put(key, value) - 如果密钥已经存在,则变更其数据值;如果密钥不存在,则插入该组「密钥/数据值」。当缓存容量达到上限时,它应该在写入新数据之前删除最久未使用的数据

2020-05-25 23:48:30 95

原创 leetcode 4. 寻找两个正序数组的中位数

leetcode 4. 寻找两个正序数组的中位数题目详情题目链接给定两个大小为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出这两个正序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n))。你可以假设 nums1 和 nums2 不会同时为空。示例 1:nums1 = [1, 3]nums2 = [2]则中位数是 2.0示例 2:nums1 = [1, 2]nums2 = [3, 4]则中位数是 (2 + 3)/2 = 2.5我的

2020-05-24 20:12:47 102

原创 leetcode 76. 最小覆盖子串

leetcode 76. 最小覆盖子串题目详情题目链接给你一个字符串 S、一个字符串 T,请在字符串 S 里面找出:包含 T 所有字符的最小子串。示例:输入: S = “ADOBECODEBANC”, T = “ABC”输出: “BANC”说明:如果 S 中不存这样的子串,则返回空字符串 “”。如果 S 中存在这样的子串,我们保证它是唯一的答案。我的代码class Solution {public: string minWindow(string s, strin

2020-05-23 23:18:12 66

原创 leetcode 105. 从前序与中序遍历序列构造二叉树

leetcode 105. 从前序与中序遍历序列构造二叉树题目详情题目链接根据一棵树的前序遍历与中序遍历构造二叉树。注意:你可以假设树中没有重复的元素。例如,给出前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7]返回如下的二叉树:3/ \9 20/ \15 7我的代码// 本道题触及到了我的只是盲区,只会手写,不会用程序来实现。我的成绩执行结果:一些想法思考建议参考官方解

2020-05-22 22:36:10 207

原创 leetcode 5. 最长回文子串

leetcode 5. 最长回文子串题目详情题目链接给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。示例 1:输入: “babad”输出: “bab”注意: “aba” 也是一个有效答案。示例 2:输入: “cbbd”输出: “bb”我的代码class Solution {public: bool isPalindrome(const string &s, int start, int end) { w

2020-05-21 19:22:01 68

原创 leetcode 1371. 每个元音包含偶数次的最长子字符串

leetcode 1371. 每个元音包含偶数次的最长子字符串题目详情题目链接给你一个字符串 s ,请你返回满足以下条件的最长子字符串的长度:每个元音字母,即 ‘a’,‘e’,‘i’,‘o’,‘u’ ,在子字符串中都恰好出现了偶数次。示例 1:输入:s = “eleetminicoworoep”输出:13解释:最长子字符串是 “leetminicowor” ,它包含 e,i,o 各 2 个,以及 0 个 a,u 。示例 2:输入:s = “leetcodeisgreat”输出:5解

2020-05-20 21:58:51 230

原创 leetcode 680. 验证回文字符串 Ⅱ

leetcode 680. 验证回文字符串 Ⅱ题目详情题目链接给定一个非空字符串 s,最多删除一个字符。判断是否能成为回文字符串。示例 1:输入: “aba”输出: True示例 2:输入: “abca”输出: True解释: 你可以删除c字符。注意:字符串只包含从 a-z 的小写字母。字符串的最大长度是50000。我的代码class Solution {public: bool isPalindromeNumber(const string &s, i

2020-05-19 21:48:46 121

原创 leetcode 152. 乘积最大子数组

leetcode 152. 乘积最大子数组题目详情题目链接给你一个整数数组 nums ,请你找出数组中乘积最大的连续子数组(该子数组中至少包含一个数字),并返回该子数组所对应的乘积。示例 1:输入: [2,3,-2,4]输出: 6解释: 子数组 [2,3] 有最大乘积 6。示例 2:输入: [-2,0,-1]输出: 0解释: 结果不能为 2, 因为 [-2,-1] 不是子数组。我的代码class Solution {public: vector<int&gt

2020-05-18 23:18:23 102

原创 leetcode 25. K 个一组翻转链表

leetcode 25. K 个一组翻转链表题目详情题目链接给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表。k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。示例:给你这个链表:1->2->3->4->5当 k = 2 时,应当返回: 2->1->4->3->5当 k = 3 时,应当返回: 3->2->1->4->5说明:你的

2020-05-16 18:36:16 93

原创 leetcode 560. 和为K的子数组

leetcode 560. 和为K的子数组题目详情题目链接给定一个整数数组和一个整数 k,你需要找到该数组中和为 k 的连续的子数组的个数。示例 1 :输入:nums = [1,1,1], k = 2输出: 2 , [1,1] 与 [1,1] 为两种不同的情况。说明 :数组的长度为 [1, 20,000]。数组中元素的范围是 [-1000, 1000] ,且整数 k 的范围是 [-1e7, 1e7]。我的代码class Solution {private: vec

2020-05-15 22:21:07 121

原创 leetcode 136. 只出现一次的数字

leetcode 136. 只出现一次的数字题目详情题目链接给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。说明:你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?示例 1:输入: [2,2,1]输出: 1示例 2:输入: [4,1,2,1,2]输出: 4我的代码class Solution {public: int singleNumber(vector<int>& nums

2020-05-14 16:27:28 59

原创 leetcode 102. 二叉树的层序遍历

leetcode 102. 二叉树的层序遍历题目详情题目链接给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。示例:二叉树:[3,9,20,null,null,15,7],3/ \9 20/ \15 7返回其层次遍历结果:[[3],[9,20],[15,7]]我的代码// Definition for a binary tree node.struct TreeNode { int val; Tree

2020-05-13 16:54:08 78

原创 leetcode 155. 最小栈

leetcode 155. 最小栈题目详情题目链接设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。push(x) —— 将元素 x 推入栈中。pop() —— 删除栈顶的元素。top() —— 获取栈顶元素。getMin() —— 检索栈中的最小元素。示例:输入:[“MinStack”,“push”,“push”,“push”,“getMin”,“pop”,“top”,“getMin”][[],[-2],[0],[-3],[],[],[],[

2020-05-12 11:16:46 88

原创 leetcode 50. Pow(x, n)

leetcode 50. Pow(x, n)题目详情题目链接实现 pow(x, n) ,即计算 x 的 n 次幂函数。示例 1:输入: 2.00000, 10输出: 1024.00000示例 2:输入: 2.10000, 3输出: 9.26100示例 3:输入: 2.00000, -2输出: 0.25000解释: 2-2 = 1/22 = 1/4 = 0.25说明:-100.0 < x < 100.0n 是 32 位有符号整数,其数值范围是 [−231,

2020-05-11 21:15:06 89

原创 leetcode 236. 二叉树的最近公共祖先

leetcode 236. 二叉树的最近公共祖先题目详情题目链接给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。百度百科中最近公共祖先的定义为:“对于有根树 T 的两个结点 p、q,最近公共祖先表示为一个结点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”例如,给定如下二叉树: root = [3,5,1,6,2,0,8,null,null,7,4]示例 1:输入: root = [3,5,1,6,2,0,8,null,null,7,

2020-05-10 22:13:45 105

原创 leetcode 69. x 的平方根

leetcode 69. x 的平方根题目详情题目链接实现 int sqrt(int x) 函数。计算并返回 x 的平方根,其中 x 是非负整数。由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。示例 1:输入: 4输出: 2示例 2:输入: 8输出: 2说明: 8 的平方根是 2.82842…,由于返回类型是整数,小数部分将被舍去。我的代码class Solution {public: int mySqrt(int x) { if

2020-05-09 21:33:38 76

原创 leetcode 221. 最大正方形

leetcode 221. 最大正方形题目详情题目链接在一个由 0 和 1 组成的二维矩阵内,找到只包含 1 的最大正方形,并返回其面积。示例:输入:1 0 1 0 01 0 1 1 11 1 1 1 11 0 0 1 0输出: 4我的代码class Solution {public: vector<vector<char>> array; int rowLen, colLen; bool allOne(int row, i

2020-05-08 22:31:33 119

原创 leetcode 572. 另一个树的子树

leetcode 572. 另一个树的子树题目详情题目链接给定两个非空二叉树 s 和 t,检验 s 中是否包含和 t 具有相同结构和节点值的子树。s 的一个子树包括 s 的一个节点和这个节点的所有子孙。s 也可以看做它自身的一棵子树。示例 1:给定的树 s:3/ \4 5/ \1 2给定的树 t:4/ \1 2返回 true,因为 t 与 s 的一个子...

2020-05-07 14:31:25 81

原创 leetcode 983. 最低票价

leetcode 983. 最低票价题目详情题目链接在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行。在接下来的一年里,你要旅行的日子将以一个名为 days 的数组给出。每一项是一个从 1 到 365 的整数。火车票有三种不同的销售方式:一张为期一天的通行证售价为 costs[0] 美元;一张为期七天的通行证售价为 costs[1] 美元;一张为期三十天的通行证售价为 ...

2020-05-06 23:13:08 95

原创 leetcode 98. 验证二叉搜索树

leetcode 98. 验证二叉搜索树题目详情题目链接给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。示例 1:输入:2/ \1 3输出: true示例 2:输入:5/ \1 4/ \3 6...

2020-05-05 22:38:09 86

原创 leetcode 45. 跳跃游戏 II

leetcode 45. 跳跃游戏 II题目详情题目链接给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。你的目标是使用最少的跳跃次数到达数组的最后一个位置。示例:输入: [2,3,1,1,4]输出: 2解释: 跳到最后一个位置的最小跳跃数是 2。从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后...

2020-05-04 23:07:41 203

原创 leetcode 3. 无重复字符的最长子串

leetcode 3. 无重复字符的最长子串题目详情题目链接给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。示例 1:输入: “abcabcbb”输出: 3解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。示例 2:输入: “bbbbb”输出: 1解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。示例 3:输入: “pwwk...

2020-05-03 23:25:39 59

原创 leetcode 53. 最大子序和

leetcode 3. 无重复字符的最长子串题目详情题目链接给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。示例 1:输入: “abcabcbb”输出: 3解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。示例 2:输入: “bbbbb”输出: 1解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。示例 3:输入: “pwwk...

2020-05-02 23:44:27 61

原创 leetcode 21. 合并两个有序链表

leetcode 21. 合并两个有序链表题目详情题目链接将两个升序链表合并为一个新的升序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。示例:输入:1->2->4, 1->3->4输出:1->1->2->3->4->4我的代码// Definition for singly-linked list.str...

2020-05-01 22:32:01 72

空空如也

空空如也

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

TA关注的人

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