![](https://img-blog.csdnimg.cn/20210829160949505.png?x-oss-process=image/resize,m_fixed,h_224,w_224)
leetcode
leetcode数据库题目以及算法题目
01-01
这个作者很懒,什么都没留下…
展开
-
剑指 Offer 58 - I. 翻转单词顺序
输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. ",则输出"student. a am I"。示例 1:输入: "the sky is blue"输出:"blue is sky the"示例 2:输入: " hello world! "输出:"world! hello"解释: 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。示例 3:输入: "...原创 2021-09-06 19:53:27 · 149 阅读 · 0 评论 -
剑指 Offer 57. 和为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^51 <= nums[i]<...原创 2021-09-06 19:53:12 · 129 阅读 · 0 评论 -
剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。示例:输入:nums =[1,2,3,4]输出:[1,3,2,4]注:[3,1,2,4] 也是正确的答案之一。提示:0 <= nums.length <= 500001 <= nums[i] <= 10000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/diao-zheng...原创 2021-09-06 19:52:58 · 64 阅读 · 0 评论 -
剑指 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...原创 2021-09-05 22:25:53 · 60 阅读 · 0 评论 -
剑指 Offer 25. 合并两个排序的链表
输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。示例1:输入:1->2->4, 1->3->4输出:1->1->2->3->4->4限制:0 <= 链表长度 <= 1000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/he-bing-liang-ge-pai-xu-de-lian-biao-lcof著作权归领扣网络所有。商业转载请联系官.原创 2021-09-05 22:01:51 · 78 阅读 · 0 评论 -
剑指 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-bia.原创 2021-09-05 21:38:51 · 54 阅读 · 0 评论 -
剑指 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的第三个节点,那么在调用了你的函...原创 2021-09-04 18:53:40 · 85 阅读 · 0 评论 -
剑指 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:输入:ro...原创 2021-09-04 18:46:30 · 78 阅读 · 0 评论 -
剑指 Offer 27. 二叉树的镜像
请完成一个函数,输入一个二叉树,该函数输出它的镜像。例如输入:4/ \2 7/ \ / \1 3 6 9镜像输出:4/ \7 2/ \ / \9 6 31示例 1:输入:root = [4,2,7,1,3,6,9]输出:[4,7,2,9,6,3,1]限制:0 <= 节点个数 <= 1000来源:力扣(LeetCode)链接:https://...原创 2021-09-04 18:29:51 · 61 阅读 · 0 评论 -
剑指 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 = [4...原创 2021-09-04 13:08:29 · 52 阅读 · 0 评论 -
剑指 Offer 32 - III. 从上到下打印二叉树 III
请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [20,9], [15,7]]提示:节点总数 <= 1000来源:力扣(LeetCode)链接:https://leetc...原创 2021-09-03 20:31:18 · 56 阅读 · 0 评论 -
剑指 Offer 32 - II. 从上到下打印二叉树 II
从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [9,20], [15,7]]提示:节点总数 <= 1000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/cong-shang-dao-xi...原创 2021-09-02 22:50:39 · 73 阅读 · 0 评论 -
剑指 Offer 32 - I. 从上到下打印二叉树
从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。例如:给定二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回:[3,9,20,15,7]提示:节点总数 <= 1000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/cong-shang-dao-xia-da-yin-er-cha-shu-lcof著作权归...原创 2021-08-29 16:04:50 · 90 阅读 · 0 评论 -
剑指 Offer 50. 第一个只出现一次的字符
在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。示例:s = "abaccdeff"返回 "b"s = ""返回 " "限制:0 <= s 的长度 <= 50000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/di-yi-ge-zhi-chu-xian-yi-ci-de-zi-fu-lcof著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。...原创 2021-08-29 15:30:15 · 72 阅读 · 0 评论 -
剑指 Offer 11. 旋转数组的最小数字
把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如,数组[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/problems/xuan-zhuan-shu-zu-de-zui-xiao-shu-...原创 2021-08-26 21:47:41 · 45 阅读 · 0 评论 -
剑指 Offer 04. 二维数组中的查找
在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个高效的函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。示例:现有矩阵 matrix 如下:[ [1, 4, 7, 11, 15], [2, 5, 8, 12, 19], [3, 6, 9, 16, 22], [10, 13, 14, 17, 24], [18, 21, 23, 26, 30]]给定 target=...原创 2021-08-25 22:49:42 · 115 阅读 · 0 评论 -
剑指 Offer 53 - II. 0~n-1中缺失的数字
此题目可以跟这个题对照着看:https://blog.csdn.net/qq_35354855/article/details/119906864一个长度为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 <= 数组长度 <= 1000..原创 2021-08-25 22:00:31 · 91 阅读 · 0 评论 -
剑指 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)链接:http...原创 2021-08-25 21:29:37 · 75 阅读 · 0 评论 -
剑指 Offer 03. 数组中重复的数字
找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。示例 1:输入:[2, 3, 1, 0, 2, 5, 3]输出:2 或 3限制:2 <= n <= 100000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/shu-zu-zhong-zhong-...原创 2021-08-24 15:57:10 · 44 阅读 · 0 评论 -
剑指 Offer 58 - II. 左旋转字符串
字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。示例 1:输入: s = "abcdefg", k = 2输出:"cdefgab"示例 2:输入: s = "lrloseumgh", k = 6输出:"umghlrlose"限制:1 <= k < s.length <= 10000来源:力扣(L...原创 2021-08-24 15:50:00 · 60 阅读 · 0 评论 -
剑指 Offer 05. 替换空格
请实现一个函数,把字符串 s 中的每个空格替换成"%20"。示例 1:输入:s = "We are happy."输出:"We%20are%20happy."限制:0 <= s 的长度 <= 10000来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/ti-huan-kong-ge-lcof著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。java中的String不可变,所以我们需要使..原创 2021-08-24 15:44:06 · 43 阅读 · 0 评论 -
剑指 Offer 35. 复杂链表的复制
请实现 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:输入:head = [[1,1],[2,1]]输出:[[1,1],[2,1]]示例 3:输入:head.原创 2021-08-24 15:33:25 · 59 阅读 · 0 评论 -
剑指 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著作权归领扣网络所有。商业转载请联系官方授权..原创 2021-08-24 15:18:45 · 63 阅读 · 0 评论 -
剑指 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著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。题目要求反向输出链表每个节点的值,需要...原创 2021-08-24 15:06:55 · 59 阅读 · 0 评论 -
剑指 Offer 30. 包含min函数的栈
题目链接:https://leetcode-cn.com/problems/bao-han-minhan-shu-de-zhan-lcof/定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。由题目中定义,该类型中既要有栈的数据结构,也要有一个存储最小元素的数据结构。那么我们定义两个栈,一个用来存储栈本来的数据,一个用来存储栈中的最小元素。代码:class MinStack {原创 2021-08-24 14:55:29 · 37 阅读 · 0 评论 -
剑指 Offer 09. 用两个栈实现队列
题目链接https://leetcode-cn.com/problems/yong-liang-ge-zhan-shi-xian-dui-lie-lcof/队列的功能是先进先出,栈的功能是先进后出。一个栈是绝对无法实现队列功能的,而我们用两个栈,可以实现一个栈A先存入数据,然后数据出栈存入另外一个栈B,这样栈A的栈底就变成了栈B的栈顶,实现了队列的先进先出的功能。栈A实现加入队尾,栈B实现删除队首。代码如下:class CQueue { LinkedList<Integ原创 2021-08-24 14:44:44 · 47 阅读 · 0 评论 -
[牛客数据库题目02] 查找入职员工时间排名倒数第三的员工所有信息
简单题题目描述:有一个员工employees表简况如下:建表语句如下:CREATETABLE`employees`(`emp_no`int(11)NOTNULL,`birth_date`dateNOTNULL,`first_name`varchar(14)NOTNULL,`last_name`varchar(16)NOTNULL,`gender`char(1)NOTNULL,`hire_date`dateNOTNULL,PRIM...原创 2021-06-19 15:48:24 · 51 阅读 · 0 评论 -
[leetcode数据库15] 1821. 寻找今年具有正收入的客户
leetcode数据库题目,简单题,面试中出现概率约为20%题目描述:表:Customers+--------------+------+| Column Name | Type |+--------------+------+| customer_id | int || year | int || revenue | int |+--------------+------+(customer_id, year) 是这个表的主键。这个表包含客原创 2021-06-21 12:05:41 · 154 阅读 · 0 评论 -
[leetcode数据库14] 183. 从不订购的客户
leetcode数据库题目,简单题,面试中出现概率约为25%[leetcode数据库14] 183. 从不订购的客户题目描述:某网站包含两个表,Customers 表和 Orders 表。编写一个 SQL 查询,找出所有从不订购任何东西的客户。原创 2021-06-21 12:04:02 · 61 阅读 · 0 评论 -
[leetcode数据库13] 1873. Calculate Special Bonus
leetcode数据库题目,简单题,面试中出现概率约为30%[leetcode数据库13] 1873. Calculate Special Bonus题目描述:Table: Employees原创 2021-06-19 15:50:07 · 272 阅读 · 0 评论 -
[leetcode数据库12] 620. 有趣的电影
leetcode数据库题目,简单题,面试中出现概率约为30%[leetcode数据库12] 620. 有趣的电影题目描述:某城市开了一家新的电影院,吸引了很多人过来看电影。该电影院特别注意用户体验,专门有个 LED显示板做电影推荐,上面公布着影评和相关电影描述。作为该电影院的信息部主管,您需要编写一个 SQL查询,找出所有影片描述为非boring(不无聊)的并且 id 为奇数的影片,结果请按等级 rating 排列。原创 2021-06-19 15:49:54 · 130 阅读 · 0 评论 -
[leetcode数据库11] 595. 大的国家
leetcode数据库题目,简单题,面试中出现概率约为30%题目描述:这里有张World 表+-----------------+------------+------------+--------------+---------------+| name | continent | area | population | gdp |+-----------------+------------+------------+---.原创 2021-06-19 15:49:32 · 82 阅读 · 0 评论 -
[leetcode数据库10] 511. 游戏玩法分析 I
leetcode数据库题目,简单题,面试中出现频率约为30%[leetcode数据库10] 511. 游戏玩法分析 I题目描述:活动表Activity:原创 2021-06-19 15:49:24 · 89 阅读 · 0 评论 -
[leetcode数据库09] 627. 变更性别
leetcode数据库题目,简单题,面试中出现概率约为35%[leetcode数据库09] 627. 变更性别题目描述:题目给定一个salary表,如下所示,有 m = 男性 和 f = 女性 的值。交换所有的 f 和 m 值(例如,将所有 f 值更改为 m,反之亦然)。要求只使用一个更新(Update)语句,并且没有中间的临时表。注意,您必只能写一个 Update 语句,请不要编写任何 Select 语句。原创 2021-06-19 15:49:14 · 79 阅读 · 0 评论 -
[leetcode数据库08] 182. 查找重复的电子邮箱
leetcode数据库题目,简单题,面试中出现概率约为40%[leetcode数据库08] 182. 查找重复的电子邮箱原创 2021-06-19 15:49:06 · 310 阅读 · 0 评论 -
[leetcode数据库07] 1179. 重新格式化部门表
leetcode数据库题目,简单题,面试中出现概率为40%题目描述:部门表Department:+---------------+---------+| Column Name | Type |+---------------+---------+| id | int || revenue | int || month | varchar |+---------------+---------+(id,.原创 2021-06-19 15:48:55 · 61 阅读 · 0 评论 -
[leetcode数据库06] 197. 上升的温度
leetcode数据库题目,简单题,面试出现频率40%[leetcode数据库06] 197. 上升的温度原创 2021-06-19 15:48:41 · 73 阅读 · 0 评论 -
[牛客数据库题目01] 查找最晚入职员工的所有信息
入门级题目题目描述:[牛客数据库题目01] 查找最晚入职员工的所有信息请你查找employees里最晚入职员工的所有信息,以上例子输出如下:原创 2021-06-19 15:47:39 · 83 阅读 · 0 评论 -
[leetcode数据库05] 196. 删除重复的电子邮箱
leetcode数据库题目,简单题,面试中出现频率为45%既然是删除重复的邮箱,又是保留重复邮箱里的id最小的那个,那么可以先查出来重复邮箱中id最小的那一批集合,然后对比原表中id,删除不在集合中的id即可知识点:delete,内连接,group by,not in,not exists题目描述:编写一个 SQL 查询,来删除Person表中所有重复的电子邮箱,重复的邮箱里只保留Id最小的那个。原创 2021-06-16 10:21:03 · 300 阅读 · 0 评论 -
[leetcode数据库04] 181. 超过经理收入的员工
leetcode数据库题目,简单题,面试中出现概率为45%如果你不确定选取哪一个表的参数在前,哪个表的参数在后,那么你可以先join输出一下结果,看一下join的中间表,在进行参数比较。知识点:join题目:Employee表包含所有员工,他们的经理也属于员工。每个员工都有一个 Id,此外还有一列对应员工的经理的 Id。原创 2021-06-15 20:53:33 · 81 阅读 · 0 评论