
每日一题
文章平均质量分 76
小可爱amour
magic_coder_sun,一个可爱的小绿博主
展开
-
整数反转 回文数 GO语言
题目给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。如果反转后整数超过 32 位的有符号整数的范围[−231,231− 1] ,就返回 0。假设环境不允许存储 64 位整数(有符号或无符号)。示例 1:输入:x = 123输出:321示例 2:输入:x = -123输出:-321示例 3:输入:x = 120输出:21示例 4:输入:x = 0输出:0提示:-231<= x <= 231- 1fun...原创 2021-11-12 22:24:29 · 322 阅读 · 0 评论 -
725. 分隔链表 借助非递归排序思路,拆分链表
题目给定一个头结点为 root 的链表, 编写一个函数以将链表分隔为 k 个连续的部分。每部分的长度应该尽可能的相等: 任意两部分的长度差距不能超过 1,也就是说可能有些部分为 null。这k个部分应该按照在链表中出现的顺序进行输出,并且排在前面的部分的长度应该大于或等于后面的长度。返回一个符合上述规则的链表的列表。举例: 1->2->3->4, k = 5 // 5 结果 [ [1], [2], [3], [4], null ]示例 1:输入:root .原创 2020-10-27 21:24:17 · 143 阅读 · 0 评论 -
445. 两数相加 II 两种解法(数组和栈)
题目给你两个 非空 链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储一位数字。将这两数相加会返回一个新的链表。你可以假设除了数字 0 之外,这两个数字都不会以零开头。进阶:如果输入链表不能修改该如何处理?换句话说,你不能对列表中的节点进行翻转。示例:输入:(7 -> 2 -> 4 -> 3) + (5 -> 6 -> 4)输出:7 -> 8 -> 0 -> 7解析该题目有一个困惑点,就是结..原创 2020-10-27 20:50:34 · 166 阅读 · 0 评论 -
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) 。数组中只有一个重复的数字,但它可能不止重复出现一次。解法:二分法class Sol...原创 2020-10-23 19:07:16 · 111 阅读 · 0 评论 -
88. 合并两个有序数组 一遍遍历,减少临时变量
题目给你两个有序整数数组nums1 和 nums2,请你将 nums2 合并到nums1中,使 nums1 成为一个有序数组。说明:初始化nums1 和 nums2 的元素数量分别为m 和 n 。你可以假设nums1有足够的空间(空间大小大于或等于m + n)来保存 nums2 中的元素。示例:输入:nums1 = [1,2,3,0,0,0], m = 3nums2 = [2,5,6], n = 3输出:[1,2,2,3,5,6]解法:...原创 2020-10-22 21:28:26 · 159 阅读 · 0 评论 -
86. 分隔链表 哨兵节点,两种实现
题目给定一个链表和一个特定值x,对链表进行分隔,使得所有小于x的节点都在大于或等于x的节点之前。你应当保留两个分区中每个节点的初始相对位置。示例:输入: head = 1->4->3->2->5->2, x = 3输出: 1->2->2->4->3->5解法1:哨兵节点,在原链表挑小数节点到辅助链表里class Solution {public: ListNode* partition(ListN...原创 2020-10-21 19:56:44 · 126 阅读 · 0 评论 -
80. 删除排序数组中的重复项 II 双指针的两种解法
题目给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。示例1:给定 nums = [1,1,1,2,2,3],函数应返回新长度 length = 5, 并且原数组的前五个元素被修改为 1, 1, 2, 2, 3 。你不需要考虑数组中超出新长度后面的元素。示例2:给定 nums = [0,0,1,1,1,1,2,3,3],函数应返回..原创 2020-10-21 18:52:15 · 103 阅读 · 0 评论 -
75. 颜色分类 2+1指针和三指针两种方法,算法原理分析
75. 颜色分类给定一个包含红色、白色和蓝色,一共n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。此题中,我们使用整数 0、1 和 2 分别表示红色、白色和蓝色。注意:不能使用代码库中的排序函数来解决这道题。示例:输入: [2,0,2,1,1,0]输出: [0,0,1,1,2,2]进阶:一个直观的解决方案是使用计数排序的两趟扫描算法。首先,迭代计算出0、1 和 2 元素的个数,然后按照0、1、2的排序,重写当前数组。你能想..原创 2020-10-16 20:44:42 · 225 阅读 · 0 评论 -
61. 旋转链表 详细思路和细节解析 双指针
61. 旋转链表给定一个链表,旋转链表,将链表每个节点向右移动k个位置,其中k是非负数。示例1:输入: 1->2->3->4->5->NULL, k = 2输出: 4->5->1->2->3->NULL解释:向右旋转 1 步: 5->1->2->3->4->NULL向右旋转 2 步: 4->5->1->2->3->NULL示例2:输入: 0->...原创 2020-10-16 18:56:38 · 162 阅读 · 0 评论 -
42. 接雨水 时间空间优化,双指针,用栈等五种方法
42. 接雨水[hard]给定n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。感谢 Marcos 贡献此图。示例:输入: [0,1,0,2,1,0,1,3,2,1,2,1]输出: 6思路 如果走到每一格,知道该格能达到最高的水位就好了。这确实是个好想法,所以该想想怎么去求每格最高水...原创 2020-10-15 20:35:16 · 184 阅读 · 0 评论 -
19. 删除链表的倒数第N个节点 一次遍历和两次遍历实现(有哨兵和无哨兵)三种解法
19. 删除链表的倒数第N个节点给定一个链表,删除链表的倒数第n个节点,并且返回链表的头结点。示例:给定一个链表: 1->2->3->4->5, 和 n = 2.当删除了倒数第二个节点后,链表变为 1->2->3->5.说明:给定的 n保证是有效的。进阶:你能尝试使用一趟扫描实现吗?解法1:两次遍历,单指针 第一遍遍历计算长度,第二遍删除节点,倒数第N个,就是正数第len-N+1个,即找第len-N个节点完成...原创 2020-10-14 20:49:47 · 223 阅读 · 0 评论 -
316. 去除重复字母 用hash表记录字母出现次数,贪心法一个个字符处理
题目给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。需保证 返回结果的字典序最小(要求不能打乱其他字符的相对位置)。注意:该题与 1081 https://leetcode-cn.com/problems/smallest-subsequence-of-distinct-characters 相同示例 1:输入:s = "bcabc"输出:"abc"示例 2:输入:s = "cbacdcbc"输出:"acdb"提示:1 <= s.原创 2020-10-13 21:31:09 · 216 阅读 · 0 评论 -
16. 最接近的三数之和 无短路判断
题目给定一个包括n 个整数的数组nums和 一个目标值target。找出nums中的三个整数,使得它们的和与target最接近。返回这三个数的和。假定每组输入只存在唯一答案。示例:输入:nums = [-1,2,1,-4], target = 1输出:2解释:与 target 最接近的和是 2 (-1 + 2 + 1 = 2) 。提示:3 <= nums.length <= 10^3 -10^3<= nums[i]<= 10^3 -1...原创 2020-10-13 21:24:05 · 97 阅读 · 0 评论 -
3. 无重复字符的最长子串 30. 串联所有单词的子串 滑动窗口 C/GO语言
题目给定一个字符串,请你找出其中不含有重复字符的最长子串的长度。示例1:输入: "abcabcbb"输出: 3解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。示例 2:输入: "bbbbb"输出: 1解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。示例 3:输入: "pwwkew"输出: 3解释: 因为无重复字符的最长子串是"wke",所以其长度为 3。 请注意,你的答案必须是 子串 的长度,"pwke"是一个子序列...原创 2020-10-12 20:23:32 · 205 阅读 · 0 评论 -
128. 最长连续序列 找目标序列的最小数或者最大数
题目给定一个未排序的整数数组,找出最长连续序列的长度。要求算法的时间复杂度为O(n)。示例:输入:[100, 4, 200, 1, 3, 2]输出: 4解释: 最长连续序列是 [1, 2, 3, 4]。它的长度为 4。思路最长连续序列一定是从序列的最小数开始,到序列的最大数结束,或者最大数到最小数。无需重复计算,只需指定一种方向,这里找最小数到最大数的序列长度。 若一个数小1的数在集合里出现,则这个数不是最小数,则其增长序列一定不是最长的。解法:将所有数放到ha..原创 2020-10-12 20:08:21 · 196 阅读 · 0 评论 -
面试题 17.14. 最小K个数 347. 前 K 个高频元素
面试题 17.14. 最小K个数题目设计一个算法,找出数组中最小的k个数。以任意顺序返回这k个数均可。示例:输入: arr = [1,3,5,7,2,4,6,8], k = 4输出: [1,2,3,4]提示:0 <= len(arr) <= 1000000 <= k <= min(100000, len(arr))class Solution {public: vector<int> smallestK(vector<i原创 2020-09-11 15:36:55 · 209 阅读 · 1 评论 -
75. 颜色分类 三数不稳定排序,一次遍历
题目给定一个包含红色、白色和蓝色,一共n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。此题中,我们使用整数 0、1 和 2 分别表示红色、白色和蓝色。注意:不能使用代码库中的排序函数来解决这道题。示例:输入: [2,0,2,1,1,0]输出: [0,0,1,1,2,2]进阶:一个直观的解决方案是使用计数排序的两趟扫描算法。首先,迭代计算出0、1 和 2 元素的个数,然后按照0、1、2的排序,重写当前数组。你能想出一个仅使用..原创 2020-09-09 19:57:29 · 121 阅读 · 0 评论 -
67. 二进制求和
67. 二进制求和题目给你两个二进制字符串,返回它们的和(用二进制表示)。输入为非空字符串且只包含数字1和0。示例1:输入: a = "11", b = "1"输出: "100"示例2:输入: a = "1010", b = "1011"输出: "10101"class Solution {public: string addBinary(string a, string b) { int lenA = a.length();...原创 2020-09-08 19:40:48 · 199 阅读 · 0 评论 -
64. 最小路径和 62. 不同路径 63. 不同路径 II 动态规划系列
64. 最小路径和题目给定一个包含非负整数的mxn网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。说明:每次只能向下或者向右移动一步。示例:输入:[ [1,3,1], [1,5,1], [4,2,1]]输出: 7解释: 因为路径 1→3→1→1→1 的总和最小。解法: 直接利用原数组vector<vector<int>> res(rows, vector<int>(cols, 0));c...原创 2020-09-08 15:36:58 · 182 阅读 · 0 评论 -
46. 全排列 47. 全排列 II
46. 全排列给定一个没有重复数字的序列,返回其所有可能的全排列。示例:输入: [1,2,3]输出:[ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1]]解法:class Solution {public: void trace(vector<vector<int>>& res, vector<int>& nums, int i...原创 2020-09-04 18:32:25 · 116 阅读 · 0 评论 -
328. 奇偶链表 链表一分为二及细节处理
题目描述给定一个单链表,把所有的奇数节点和偶数节点分别排在一起。请注意,这里的奇数节点和偶数节点指的是节点编号的奇偶性,而不是节点的值的奇偶性。请尝试使用原地算法完成。你的算法的空间复杂度应为 O(1),时间复杂度应为 O(nodes),nodes 为节点总数。示例 1:输入: 1->2->3->4->5->NULL输出: 1->3->5->2->4->NULL示例 2:输入: 2->1->3->5-&g原创 2020-09-01 18:17:26 · 141 阅读 · 0 评论 -
283. 移动零 双指针的三种解法
题目描述给定一个数组nums,编写一个函数将所有0移动到数组的末尾,同时保持非零元素的相对顺序。示例:输入: [0,1,0,3,12]输出: [1,3,12,0,0]说明:必须在原数组上操作,不能拷贝额外的数组。 尽量减少操作次数。解法1:双指针,第一个0与其后第一个非0匹配交换class Solution {public: void moveZeroes(vector<int>& nums) { int len ...原创 2020-08-31 19:41:30 · 157 阅读 · 0 评论 -
278. 第一个错误的版本 (二分法求mid的陷阱)
这道题目就是一个金典的二分法,但是在求mid的时候有个小陷阱。 在二分查找中,选取mid 的方法一般为mid = (left + right)>>1 如果使用的编程语言会有整数溢出的情况(例如 C++,Java),那么可以用left + (right - left)/2 代替前者。由于/和%的效率较低(约低一个量级),这里我们通常会选择用>>代替/,所以问题又来了,用left + (right -...原创 2020-08-31 17:14:53 · 260 阅读 · 0 评论 -
268. 缺失数字 (求和/异或/哈希/排序)
题目描述给定一个包含0, 1, 2, ..., n中n个数的序列,找出 0 ..n中没有出现在序列中的那个数。示例 1:输入: [3,0,1]输出: 2示例2:输入: [9,6,4,2,3,5,7,0,1]输出: 8解法1:求和,线性复杂度/常数空间,注意溢出class Solution {public: int missingNumber(vector<int>& nums) { int len = n...原创 2020-08-31 16:43:42 · 164 阅读 · 0 评论 -
21. 合并两个有序链表 23. 合并K个排序链表(递归和迭代) 14. 最长公共前缀(四种思路解析)
21. 合并两个有序链表题目:将两个升序链表合并为一个新的升序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。解法:/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), n..原创 2020-07-08 19:16:04 · 142 阅读 · 0 评论 -
2. 两数相加
题目:给出两个非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照逆序的方式存储的,并且它们的每个节点只能存储一位数字。如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。您可以假设除了数字 0 之外,这两个数都不会以 0开头。示例:输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)输出:7 -> 0 -> 8原因:342 + 465 = 807题目要点:链表头部是低位,直接相加即可,...原创 2020-07-07 19:36:13 · 114 阅读 · 0 评论 -
1. 两数之和 15. 三数之和 18. 四数之和 16. 最接近的三数之和 (解法的共性和差异)
1. 两数之和题目:给定一个整数数组 nums和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。题目要点:1:数组无序。2:因为是返回数的下标,排序再用双指针需要额外维护数的原索引。解法1:穷遍历class Solution {public: vector<int> twoSum(vector<int>& nums...原创 2020-07-07 19:27:37 · 272 阅读 · 0 评论 -
80. 删除排序数组中的重复项 II
80. 删除排序数组中的重复项 II题目:给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素最多出现两次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。解法:class Solution {public: int removeDuplicates(vector<int>& nums) { int len = nums.size(); if (le原创 2020-07-06 20:32:02 · 86 阅读 · 0 评论 -
88. 合并两个有序数组
题目:给你两个有序整数数组nums1 和 nums2,请你将 nums2 合并到nums1中,使 nums1 成为一个有序数组。说明:初始化nums1 和 nums2 的元素数量分别为m 和 n 。你可以假设nums1有足够的空间(空间大小大于或等于m + n)来保存 nums2 中的元素。解法:从后往前处理class Solution {public: void merge(vector<int>& nums1, int m, vect...原创 2020-07-06 20:22:57 · 115 阅读 · 0 评论 -
83/82. 删除排序链表中的重复元素 I/ II (内存释放和不释放版本对比)
83. 删除排序链表中的重复元素题目:给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。解法:释放内存版/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {public: L原创 2020-07-06 20:20:13 · 117 阅读 · 0 评论 -
86. 分隔链表 (两种解法)
题目:给定一个链表和一个特定值x,对链表进行分隔,使得所有小于x的节点都在大于或等于x的节点之前。你应当保留两个分区中每个节点的初始相对位置。示例:输入: head = 1->4->3->2->5->2, x = 3输出: 1->2->2->4->3->5解法1:一个链表,一个个节点找,有就拿到前面/** * Definition for singly-linked list. * struct Li...原创 2020-07-06 20:15:21 · 135 阅读 · 0 评论 -
98. 验证二叉搜索树 (三种实现)
题目:给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。解法1:由上而下,递归传入上下限/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right;原创 2020-07-06 19:57:46 · 824 阅读 · 0 评论 -
55. 跳跃游戏 (两种解法)
题目:给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个位置。示例1:输入: [2,3,1,1,4]输出: true解释: 我们可以先跳 1 步,从位置 0 到达 位置 1, 然后再从位置 1 跳 3 步到达最后一个位置。示例2:输入: [3,2,1,0,4]输出: false解释: 无论怎样,你总会到达索引为 3 的位置。但该位置的最大跳跃长度是 0 , 所以你永远不可能到达最后一个位置。解法..原创 2020-07-05 16:24:41 · 2682 阅读 · 0 评论 -
148. 排序链表 非递归
题目:在O(nlogn) 时间复杂度和常数级空间复杂度下,对链表进行排序解法:/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {private: int cntListLen(...原创 2020-07-05 12:08:12 · 2869 阅读 · 0 评论 -
147. 对链表进行插入排序 148. 排序链表(归并排序)
题目:对链表进行插入排序。插入排序算法:插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其插入。重复直到所有输入数据插入完为止。解法1:将所有数都放到vetor里,进行数组的插入排序解法2:class Solution {public: ListNode* insertionSortList(ListNode* head) { if原创 2020-07-05 11:20:50 · 93 阅读 · 0 评论 -
146. LRU缓存机制 460. LFU缓存
146. LRU缓存机制题目:运用你所掌握的数据结构,设计实现一个LRU (最近最少使用) 缓存机制。它应该支持以下操作: 获取数据 get 和 写入数据 put 。获取数据 get(key) - 如果关键字 (key) 存在于缓存中,则获取关键字的值(总是正数),否则返回 -1。写入数据 put(key, value) - 如果关键字已经存在,则变更其数据值;如果关键字不存在,则插入该组「关键字/值」。当缓存容量达到上限时,它应该在写入新数据之前删除最久未使用的数据值,从而为新的数据值留..原创 2020-07-22 16:52:16 · 132 阅读 · 0 评论 -
144. 二叉树的前序遍历 145. 二叉树的后序遍历 94. 二叉树的中序遍历(多种解法的进阶)
144. 二叉树的前序遍历题目:给定一个二叉树,返回它的前序遍历。示例:输入: [1,null,2,3] 1 \ 2 / 3 输出: [1,2,3]解法1:递归class Solution {private: void takeVal(TreeNode *root, vector<int>& res) { if (NULL == root) return;..原创 2020-07-03 18:39:50 · 3603 阅读 · 0 评论 -
143. 重排链表 步骤分解
题目:给定一个单链表L:L0→L1→…→Ln-1→Ln ,将其重新排列后变为: L0→Ln→L1→Ln-1→L2→Ln-2→…你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。示例1:给定链表 1->2->3->4, 重新排列为 1->4->2->3.示例 2:给定链表 1->2->3->4->5, 重新排列为 1->5->2->4->3.解题分析: 当链表节点数...原创 2020-07-03 16:07:26 · 450 阅读 · 0 评论 -
141. 环形链表 142. 环形链表 II (数学分析)
141. 环形链表题目:给定一个链表,判断链表中是否有环。为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。解法:快慢指针class Solution {public: bool hasCycle(ListNode *head) { if (NULL == head) return false; ListNo.原创 2020-07-03 12:21:51 · 2698 阅读 · 0 评论 -
120. 三角形最小路径和 (自下而上和自上而下两种解法)
题目:给定一个三角形,找出自顶向下的最小路径和。每一步只能移动到下一行中相邻的结点上。相邻的结点 在这里指的是 下标 与 上一层结点下标 相同或者等于 上一层结点下标 + 1 的两个结点。题目链接例如,给定三角形:[ [2], [3,4], [6,5,7], [4,1,8,3]]自顶向下的最小路径和为11(即,2+3+5+1= 11)。解法1:常规递归,超时class Solution {private: void fi...原创 2020-07-02 19:17:29 · 154 阅读 · 0 评论