自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

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

转载 leetcode 40 重建二叉树

leetcode 重建二叉树题目:输入某二叉树的前序遍历和中序遍历的结果,请构建该二叉树并返回其根节点。假设输入的前序遍历和中序遍历的结果中都不含重复的数字示例1:Input: preorder = [3,9,20,15,7], inorder = [9,3,15,20,7]Output: [3,9,20,null,null,15,7]示例 2:Input: preorder = [-1], inorder = [-1]Output: [-1]限制: 0 <

2022-03-06 12:50:23 140

转载 LeetCoed 39 二叉树的深度

题目:输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。例如:给定二叉树 [3,9,20,null,null,15,7], ·3 / \ 9 20 / \ 15 7返回它的最大深度3 。...

2022-03-04 23:04:07 102

转载 LeetCode 38 最小的k个数

题目:输入整数数组arr,找出其中最小的k个数。例如,输入4、5、1、6、2、7、3、8这8个数字,则最小的4个数字是1、2、3、4。示例 1:输入:arr = [3,2,1], k = 2输出:[1,2] 或者 [2,1]示例 2:输入:arr = [0,1,2,1], k = 1输出:[0]限制:0 <= k <= arr.length <= 10000 ;0 <= arr[i] <= ...

2022-03-03 22:10:59 325

转载 LeetCode 37 把数组排成最小的数

示例 1:输入: [10,2]输出: "102"示例2:输入: [3,30,34,5,9]输出: "3033459"提示: 0 < nums.length <= 100解题思路:此题求拼接起来的最小数字,本质上是一个排序问题。设数组 nums 中任意两数字的字符串为 x 和 y ,则规定 排序判断规则 为:若拼接字符串x + y >...

2022-03-02 21:40:09 296

转载 LeetCode 36 扑克牌中的顺子

题目:给定一棵二叉搜索树,请找出其中第k大的节点的值。示例 1:输入: root = [3,1,4,null,2], k = 1 3 / \1 4 \ 2输出: 4示例 2:输入: root = [5,3,6,2,4,null,null,1], k = 3 ...

2022-03-02 21:20:43 127

转载 LeetCode 35 二叉搜索树的第k大节点

题目:给定一棵二叉搜索树,请找出其中第 k 大的节点的值。示例 1:输入: root = [3,1,4,null,2], k = 1 3 / \1 4 \ 2输出: 4示例 2:输入: root = [5,3,6,2,4,nu...

2022-03-01 19:45:13 71

转载 LeetCode 34 二叉树中和为某一值的路径

题目:给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。( 叶子节点 是指没有子节点的节点。)示例 1:输入:root = [ 5 , 4 , 8 , 11 , null , 13 , 4 , 7 , 2 , null , null , 5 , 1 ], targetSum = 22输出:[ [ 5 , 4 , 11 , 2 ] , [ 5 , 8 , 4 , 5 ] ]示例 2:输入:root = .

2022-03-01 19:38:55 133

转载 LeetCode 33 机器人的运动范围

题目:地上有一个m行n列的方格,从坐标 [0,0] 到坐标 [m-1,n-1] 。一个机器人从坐标 [0, 0] 的格子开始移动,它每次可以向左、右、上、下移动一格(不能移动到方格外),也不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k为18时,机器人能够进入方格 [35, 37] ,因为3+5+3+7=18。但它不能进入方格 [35, 38],因为3+5+3+8=19。请问该机器人能够到达多少个格子?示例 1: 输入:m = 2, n = 3, k = 1 ...

2022-03-01 16:14:22 59

转载 LeetCode 32 矩阵中的路径

题目:给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。示例 1:输入:board = [["A","B","C","E"],["S","F","C","S"],["A","D","E","E"]], word = "A...

2022-03-01 15:39:09 71

原创 2、数学基础

目录 线性代数 微积分基本知识 概率统计基础知识 线性代数 微积分基本知识 导数 偏导数 方向导数: 函数某一点在某一趋近方向(向量方向)上的导数值 方向函数就是函数在除坐标轴正方向外,其他特定方向上的变化率 梯度 函数在某一点的梯度是这样一个向量,它的方向与取得最大方向导数的方向一致,而它的模为方向导数的最大值 凸函数和凹函数 概率统计基础知识 ...

2022-02-28 21:25:09 240

转载 LeetCode 31 翻转单词顺序

题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. ",则输出"student. a am I"。示例 1:输入: "the sky is blue"输出:"blue is sky the"示例 2:输入: " hello world! "输出:"world! hello"解释: 输入字符串可以...

2022-02-28 21:01:55 162

转载 LeetCode 30 和为s的两个数字

题目:输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s。如果有多对数字的和等于s,则输出任意一对即可。示例 1:输入:nums = [2,7,11,15], target = 9输出:[2,7] 或者 [7,2]示例 2:输入:nums = [10,26,30,31,47,60], target = 40输出:[10,30] 或者 [30,10]限制:1 <= nums.length <= 10^5 1 <= nums[i]&.

2022-02-28 20:22:39 38

转载 LeetCode 29 调整数组顺序使奇数位于偶数前面

题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数在数组的前半部分,所有偶数在数组的后半部分。示例: 输入:nums = [1,2,3,4] 输出:[1,3,2,4] 注:[3,1,2,4] 也是正确的答案之一。提示:0 <= nums.length <= 50000 0 <= nums[i] <= 10000解题思路:考虑定义双指针 i , j 分列数组左右两端,循环执行:指针i从左向右寻找偶数; 指..

2022-02-28 19:24:46 43

转载 LeetCode 28 两个链表的第一个公共节点

题目:输入两个链表,找出它们的第一个公共节点。 如下面的两个链表: 在节点 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...

2022-02-28 18:54:20 108

转载 LeetCode 27 合并两个排序的链表

题目:输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。示例1: 输入:1->2->4, 1->3->4输出:1->1->2->3->4->4限制:0 <= 链表长度 <= 1000解题思路:伪头节点根据题目描述,链表 l1,l2 是递增的,因此容易想到使用双指针 l1 和 l2遍历两链表,根据 l1.val 和 l2.val 的大小关系确定节点添加顺序...

2022-02-27 23:17:39 85

转载 LeetCode 26 链表中倒数第k个节点

题目:输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点。示例:给定一个链表: 1->2->3->4->5, 和 k = 2.返回链表 4->5.解题思路:双指针第一种思路:先遍历统计链表长度,记为n; 设置一个指针走(n-k)步,即可找到链表倒数

2022-02-27 23:01:39 158

转载 LeetCode 25 删除链表的节点

题目:给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。示例 1:输入: head = [4,5,1,9], val = 5输出: [4,1,9]解释: 给定你链表中值为5的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.示例 2:输入: head = [4,5,1,9], ...

2022-02-27 22:50:07 49

转载 LeetCode 24 最长不含重复字符的子字符串

题目:请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。示例1:输入: "abcabcbb"输出: 3解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。示例 2:输入: "bbbbb"输出: 1解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。...

2022-02-27 18:15:25 207

转载 LeetCode 23 礼物的最大价值

题目:在一个 m*n 的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于 0)。你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格、直到到达棋盘的右下角。给定一个棋盘及其上面的礼物的价值,请计算你最多能拿到多少价值的礼物?示例 1:输入:[[1,3,1],[1,5,1],[4,2,1]]...

2022-02-27 17:28:57 154

转载 LeetCode 22 股票的最大利润

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

2022-02-24 21:10:34 117

转载 LeetCode 21 把数字翻译成字符串

解题思路:动态规划状态定义:设动态规划列表dp,dp[i] 代表以 xi 为结尾的数字的翻译方案数量转移方程:若 xi 和 x i−1 组成的两位数字可以被翻译,则 dp[i] = dp[i - 1] + dp[i - 2] ;否则 dp[i] = dp[i - 1] 。初始状态: dp[0] = dp[1] = 1 ,即 “无数字” 和 “第 1 位数字” 的翻译方法数量均为 1 ;返回值: dp[n] ,即此数字的翻译方案数量。class Solution {

2022-02-24 20:22:35 115

转载 LeetCode 20 连续子数组的最大和

题目:输入一个整型数组,数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。(要求时间复杂度为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解题思路...

2022-02-23 22:48:52 127

转载 LeetCode 19 树的子结构

解题思路:若树B是树A的子结构,则子结构的根节点可能为树A的任意一个节点。因此,判断树B是否是树A的子结构,需完成以下两步工作:1、先序遍历树A中的每个节点nA;(对应函数 isSubStructure(A,B))2、判断树A中以nA为根节点的子树是否包含树B。(对应函数recur(A,B))recur(A,B)函数:1、终止条件:1、当节点B为空:说明树B已匹配完成(越过叶子节点),因此返回true;...

2022-02-23 21:12:36 116

转载 LeetCode 18 对称的二叉树

思路:递归1、判断两节点 L.left 和 R.right 是否对称2、判断两节点 L.right 和 R.left 是否对称返回值:两节点都对称时,才是对称树,因此用逻辑符&&连接算法流程:isSummetric(root):特例处理:若根节点 root 为空,则直接返回 true 返回值:即 recur(root.left , root.right);recur(L,R):终止条件: 当 L 和 R 同时越过叶子节点:此树从顶至底的节点都对称,因此返

2022-02-22 20:59:36 55

转载 LeetCode 17 二叉树的镜像

题目:请完成一个函数,输入一个二叉树,该函数输出它的镜像。例如输入:4 / \ 2 7 / \ / \ 1 3 6 9镜像输出:4 ...

2022-02-22 20:07:17 104

转载 LeetCode 16 从上到下打印二叉树 III

题目:请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍...

2022-02-20 21:56:27 82

转载 LeetCode 15 从上到下打印二叉树

题目:从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。例如: 给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回:[3,9,20,15,7]提示: 节点总数 <= 1000解题思路:题目要求的二叉树...

2022-02-20 21:47:24 86

转载 LeetCode 14 从上到下打印二叉树II

题目:从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[...

2022-02-20 21:41:19 135

转载 LeetCode 13 第一个只出现一次的字符

题目:在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。示例 1:输入:s = "abaccdeff"输出:'b'示例 2:输入:s = ""输出:' '限制: 0 <= s 的长度 <= 50000思路:方法一:哈希表遍历字符串s,使用哈希表统计 “各字符数量是否> 1>1”。 再遍历字符串s...

2022-02-20 21:30:53 198

转载 LeetCode 12 旋转数组的最小数字

题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。给你一个可能存在 重复 元素值的数组 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]...

2022-02-20 21:19:13 45

转载 LeetCode 11 二维数组中的查找

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

2022-02-20 20:56:37 121

原创 推荐系统简介

推荐系统概述推荐系统的目的 用户 网站 内容推荐系统的基本思想 利用用户和物品的特征信息 利用 用户喜欢过的物品 利用和用户相似的其他用户 推荐系统的数据分析要推荐物品或内容的元数据 系统用户的基本信息 用户的行为信息(显式的用户反馈:评分或评论、隐式的用户反馈:购买或查看推荐系统的分类 根据实时性分类 离线推荐 实时推荐 根据推荐是否个性化分类 基于统计的推荐 个性化推荐 根据推荐原则...

2022-02-18 21:10:13 87

转载 LeetCode 10 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解题思路:二分法根据题意,数组可以按照以下规则划...

2022-02-18 20:47:46 39

转载 LeetCode 09 在排序数组中查找数字 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]<= 109 nums是一个非递减数组 -109...

2022-02-18 20:32:45 50

转载 LeetCode 08 数组中重复的数字

题目:找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。示例 1:输入:[2, 3, 1, 0, 2, 5, 3]输出:2 或 3限制: 2 <= n <= 100000思路:方法一:哈希表/Set算法流程:...

2022-02-18 17:03:58 77

转载 LeetCode 07 替换空格

题目:请实现一个函数,把字符串 s 中的每个空格替换成"%20"。示例 1:输入:s = "We are happy."输出:"We%20are%20happy."限制: 0 <= s 的长度 <= 10000思路:遍历添加算法流程:1、初始化一个 StringBuilder (Java) ,记为 temp;2、遍历列表 s 中的每个字符 c :3、当 c 为空格时:向 temp后添加字符串 "%20" ;4、...

2022-02-17 15:44:22 141

转载 LeetCode 06 左旋转字符串

题目:字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。示例 1:输入: s = "abcdefg", k = 2输出:"cdefgab"示例 2:输入: s = "lrloseumgh", k = 6输出:"umghlrlos...

2022-02-17 15:39:18 33

转载 LeetCode 05 复杂链表的复制

题目:请实现 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:...

2022-02-17 15:34:27 139

转载 LeetCode 04 反转链表

题目:定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。示例: 输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1->NULL限制:0 <= 节点个数 <= 5000思路:方法一:迭代(双指针)代码:class Solution { public ListNode reverseList(ListNode head) { Lis

2022-02-16 18:57:49 39

转载 Leetcode 03 从尾到头打印链表

题目:输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。示例 1:输入:head = [1,3,2]输出:[2,3,1]限制:0 <= 链表长度 <= 10000思路:反向填充数组/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int ...

2022-02-16 17:12:56 40

空空如也

空空如也

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

TA关注的人

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