
LeetCode
SoulOH
虽不能至,心向往之。
展开
-
LeetCode:498. 对角线遍历(Java)
题目:给定一个含有 M x N 个元素的矩阵(M 行,N 列),请以对角线遍历的顺序返回这个矩阵中的所有元素,对角线遍历如下图所示。示例:输入:[ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ]]输出: [1,2,4,7,5,3,6,8,9]解释:说明:给定矩阵中的元素总数不会超过 100000 。解答:恶心题。思...原创 2019-08-31 10:50:19 · 787 阅读 · 0 评论 -
LeetCode:101. 对称二叉树 (Java)
题目:给定一个二叉树,检查它是否是镜像对称的。例如,二叉树 [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说明:如果你可以运用递归和迭代...原创 2018-08-16 09:28:59 · 1632 阅读 · 0 评论 -
LeetCode:412. FizzBuzz(Python 3)
题目:写一个程序,输出从 1 到 n 数字的字符串表示。 1. 如果 n 是3的倍数,输出“Fizz”; 2. 如果 n 是5的倍数,输出“Buzz”; 3. 如果 n 同时是3和5的倍数,输出 “FizzBuzz”。 示例: n = 15, 返回:[ "1", "2", "Fizz", "4", ...原创 2018-08-18 14:01:37 · 559 阅读 · 0 评论 -
LeetCode: 26. 删除排序数组中的重复项(Java)
题目:给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。示例 1:给定数组 nums = [1,1,2], 函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为:你不需要考虑数组中超出新长度后面的元素。示例 2:...原创 2018-08-21 22:30:59 · 7342 阅读 · 6 评论 -
LeetCode:268. 缺失数字(Java)
题目:给定一个包含 0, 1, 2, ..., n 中 n 个数的序列,找出 0 .. n 中没有出现在序列中的那个数。示例 1:输入: [3,0,1]输出: 2示例 2:输入: [9,6,4,2,3,5,7,0,1]输出: 8说明:你的算法应具有线性时间复杂度。你能否仅使用额外常数空间来实现?解答:这个题有一个很直观的解法:求出0-n的和,然后求出数...原创 2018-08-13 12:54:16 · 863 阅读 · 0 评论 -
LeetCode:387. 字符串中的第一个唯一字符(Java)
题目:解答:用一个LinkedHashMap实现,key为字母,value如果第一次插入存入索引,再次插入存-1,然后遍历HashMap,找到第一个不是-1的value(LinkedHashMap保证了插入顺序,所以找到的一定是第一个唯一字符)。class Solution { public int firstUniqChar(String s) { Map&...原创 2018-08-08 16:16:48 · 718 阅读 · 0 评论 -
LeetCode: 19. 删除链表的倒数第N个节点( Java)
题目:给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。示例:给定一个链表: 1->2->3->4->5, 和 n = 2.当删除了倒数第二个节点后,链表变为 1->2->3->5.说明:给定的 n 保证是有效的。进阶:你能尝试使用一趟扫描实现吗?解答:要删除节点的前一个节点位置 = 链表长度 - n...原创 2018-08-15 17:07:10 · 209 阅读 · 0 评论 -
LeetCode:13. 罗马数字转整数(Java)
题目:罗马数字包含以下七种字符:I, V, X, L,C,D 和 M。字符 数值I 1V 5X 10L 50C 100D 500M 1000例如, 罗马数字 2 写做 II ,即为两个并...原创 2018-08-12 13:35:51 · 1768 阅读 · 0 评论 -
LeetCode:198. 打家劫舍(Java)
题目:你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。给定一个代表每个房屋存放金额的非负整数数组,计算你在不触动警报装置的情况下,能够偷窃到的最高金额。示例 1:输入: [1,2,3,1]输出: 4解释: 偷窃 1 号房屋 (金额 = 1) ...原创 2018-08-11 12:35:10 · 499 阅读 · 0 评论 -
Leetcode:350. 两个数组的交集 II(Python 3)
题目:两个数组的交集 II给定两个数组,写一个方法来计算它们的交集。例如:给定 nums1 = [1, 2, 2, 1], nums2 = [2, 2], 返回 [2, 2].注意: 输出结果中每个元素出现的次数,应与元素在两个数组中出现的次数一致。 我们可以不考虑输出结果的顺序。跟进:如果给定的数组已经排好序呢?你将如何优化你的算法? 如果 nums1 ...原创 2018-08-07 15:08:32 · 656 阅读 · 0 评论 -
LeetCode:8. 字符串转整数 (atoi)(Python 3)
题目:实现 atoi,将字符串转为整数。在找到第一个非空字符之前,需要移除掉字符串中的空格字符。如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连续的数字组合起来,这部分字符即为整数的值。如果第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。字符串可以在形成整数的字符后面包括多余的字符,这些字符可以被忽略,它们对于函数没有影响。当字符串中的第...原创 2018-08-02 12:32:08 · 339 阅读 · 0 评论 -
LeetCode:125. 验证回文串( Java)
题目:给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。说明:本题中,我们将空字符串定义为有效的回文串。示例 1:输入: "A man, a plan, a canal: Panama"输出: true示例 2:输入: "race a car"输出: false解答:先全部变成小写字母,然后从第一个/最后一个开始比对,遇到不是字母...原创 2018-08-14 15:57:53 · 1076 阅读 · 0 评论 -
LeetCode:122. 买卖股票的最佳时机 II(C++)
题目:给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。示例 1:输入: [7,1,5,3,6,4]输出: 7解释: 在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖...原创 2018-08-19 15:56:07 · 1156 阅读 · 0 评论 -
LeetCode:36. 有效的数独(Python 3)
题目:判断一个 9x9 的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可。数字 1-9 在每一行只能出现一次。 数字 1-9 在每一列只能出现一次。 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。上图是一个部分填充的有效的数独。数独部分空格内已填入了数字,空白格用 '.' 表示。示例 1:输入:[ ["5","3",".",...原创 2018-08-26 19:13:53 · 524 阅读 · 0 评论 -
LeetCode:724. 寻找数组的中心索引(Java)
题目:给定一个整数类型的数组nums,请编写一个能够返回数组“中心索引”的方法。我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和。如果数组不存在中心索引,那么我们应该返回 -1。如果数组有多个中心索引,那么我们应该返回最靠近左边的那一个。示例 1:输入:nums = [1, 7, 3, 6, 5, 6]输出: 3解释:索引...原创 2019-08-21 14:11:39 · 457 阅读 · 0 评论 -
LeetCode:283. 移动零(C++)
题目:给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。示例:输入: [0,1,0,3,12]输出: [1,3,12,0,0]说明:必须在原数组上操作,不能拷贝额外的数组。 尽量减少操作次数。解答:简单题:Approach #1: 把0删了再加在最后面。 class Solution {public: ...原创 2018-08-25 10:02:59 · 827 阅读 · 0 评论 -
LeetCode:7. 反转整数(C++)
题目:给定一个 32 位有符号整数,将整数中的数字进行反转。示例 1:输入: 123输出: 321 示例 2:输入: -123输出: -321示例 3:输入: 120输出: 21注意:假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−231, 231 − 1]。根据这个假设,如果反转后的整数溢出,则返回 0。解答:Appr...原创 2018-08-24 18:50:13 · 788 阅读 · 0 评论 -
LeetCode:242. 有效的字母异位词(C++)
题目:给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的一个字母异位词。示例 1:输入: s = "anagram", t = "nagaram"输出: true示例 2:输入: s = "rat", t = "car"输出: false说明:你可以假设字符串只包含小写字母。进阶:如果输入字符串包含 unicode 字符怎么办?你能否调整...原创 2018-09-07 09:54:02 · 1103 阅读 · 0 评论 -
LeetCode:217. 存在重复元素(C++)
题目:给定一个整数数组,判断是否存在重复元素。如果任何值在数组中出现至少两次,函数返回 true。如果数组中每个元素都不相同,则返回 false。示例 1:输入: [1,2,3,1]输出: true示例 2:输入: [1,2,3,4]输出: false示例 3:输入: [1,1,1,3,3,4,3,2,4,2]输出: true解答:方法一:对数组...原创 2018-09-03 10:12:28 · 1146 阅读 · 0 评论 -
LeetCode:234. 回文链表(C++ & Java)
题目:请判断一个链表是否为回文链表。示例 1:输入: 1->2输出: false示例 2:输入: 1->2->2->1输出: true进阶:你能否用O(n) 时间复杂度和 O(1) 空间复杂度解决此题?解答:Approach #1:随手写了一个,把链表变成了数组。然后就变成了怎样判断一个数组是回文数组,很容易用双指针解决。...原创 2019-08-30 23:37:30 · 345 阅读 · 0 评论 -
LeetCode:14. 最长公共前缀(C++)
题目:编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 ""。示例 1:输入: ["flower","flow","flight"]输出: "fl"示例 2:输入: ["dog","racecar","car"]输出: ""解释: 输入不存在公共前缀。说明:原创 2018-08-20 21:18:28 · 3061 阅读 · 0 评论 -
LeetCode:38. 报数(C++)
题目:报数序列是指一个整数序列,按照其中的整数的顺序进行报数,得到下一个数。其前五项如下:1. 12. 113. 214. 12115. 1112211 被读作 "one 1" ("一个一") , 即 11。11 被读作 "two 1s" ("两个一"), 即 21。21 被读作 "one 2", "one 1" (&q原创 2018-08-23 17:05:46 · 1568 阅读 · 1 评论 -
LeetCode:190. 颠倒二进制位(C++)
题目:颠倒给定的 32 位无符号整数的二进制位。示例:输入: 43261596输出: 964176192解释: 43261596 的二进制表示形式为 00000010100101000001111010011100 , 返回 964176192,其二进制表示形式为 00111001011110000010100101000000 。进阶:如果多次调用这个函数,你将...原创 2018-08-30 15:14:37 · 1056 阅读 · 0 评论 -
LeetCode:461. 汉明距离(Java)
两个整数之间的汉明距离指的是这两个数字对应二进制位不同的位置的数目。给出两个整数 x 和 y,计算它们之间的汉明距离。注意:0 ≤ x, y < .示例:输入: x = 1, y = 4输出: 2解释:1 (0 0 0 1)4 (0 1 0 0) ↑ ↑上面的箭头指出了对应二进制位不同的位置。解答:两个数异或,那么所...原创 2018-08-17 08:49:34 · 607 阅读 · 0 评论 -
LeetCode:66. 加一(C++)
题目:给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。你可以假设除了整数 0 之外,这个整数不会以零开头。示例 1:输入: [1,2,3]输出: [1,2,4]解释: 输入数组表示数字 123。示例 2:输入: [4,3,2,1]输出: [4,3,2,2]解释: 输入数组表...原创 2018-08-22 21:04:30 · 1002 阅读 · 0 评论 -
LeetCode:118. 杨辉三角(Python)
题目:给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。在杨辉三角中,每个数是它左上方和右上方的数的和。示例:输入: 5输出:[ [1], [1,1], [1,2,1], [1,3,3,1], [1,4,6,4,1]]解答:又是dp,巧的很,这里的每一个数都是二项式系数C(i, j)方程C(i ,j) = ...原创 2018-08-06 21:29:18 · 476 阅读 · 0 评论 -
LeetCode:108. 将有序数组转换为二叉搜索树(Java)
题目:将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树。本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1。给定有序数组: [-10,-3,0,5,9],一个可能的答案是:[0,-3,9,-10,null,5],它可以表示下面这个高度平衡二叉搜索树: 0 / \ -3 9 / / -1...原创 2018-08-10 17:04:07 · 973 阅读 · 0 评论 -
LeetCode: 104. 二叉树的最大深度(Java & Python)
题目给定一个二叉树,找出其最大深度。二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。说明:叶子节点是指没有子节点的节点。示例:给定二叉树[3,9,20,null,null,15,7],返回它的最大深度3 。解答:感觉现在会做了。递归解决,最大深度 = max(左子树的最大深度,右子树的最大深度) + 1;结束条件:根节点为空,直接retur...原创 2018-07-15 10:17:11 · 1612 阅读 · 0 评论 -
LeetCode: 21. 合并两个有序链表 (C++)
题目:解答:1. 递归解决,终止条件:l1为空或者l2位空(同时为空已经在l1那里判断了)怎样递归:l1的值比较小或者两个值相等,就把l1->next和l2合并,放进l1->next,返回l1;l2的值比较小,就把l1和l2->next合并,放进l2->next,返回l2; /** * Definition for singly-linked...原创 2018-07-25 22:05:39 · 2950 阅读 · 1 评论 -
LeetCode: 278. 第一个错误的版本(C++)
题目:你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有通过质量检测。由于每个版本都是基于之前的版本开发的,所以错误的版本之后的所有版本都是错的。假设你有 n 个版本 [1, 2, ..., n],你想找出导致之后所有版本出错的第一个错误的版本。你可以通过调用 bool isBadVersion(version) 接口来判断版本号 version 是否在单...原创 2018-07-20 14:04:43 · 1358 阅读 · 0 评论 -
LeetCode:728. 自除数(Java & Python)
题目:自除数是指可以被它包含的每一位数除尽的数。例如,128 是一个自除数,因为128 % 1 == 0,128 % 2 == 0,128 % 8 == 0。还有,自除数不允许包含 0 。给定上边界和下边界数字,输出一个列表,列表的元素是边界(含边界)内所有的自除数。示例 1:输入: 上边界left = 1, 下边界right = 22输出: [1, 2, ...原创 2018-07-14 20:14:40 · 739 阅读 · 0 评论 -
LeetCode: 617. 合并二叉树(Java & Python)
题目:给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠。你需要将他们合并为一个新的二叉树。合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否则不为NULL 的节点将直接作为新二叉树的节点。示例1:输入: Tree 1 Tree 2 ...原创 2018-07-13 21:29:05 · 778 阅读 · 0 评论 -
LeetCode: 204. 计数质数(Java)
题目:统计所有小于非负整数n的质数的数量。示例:输入: 10输出: 4解释: 小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。解答:这个题目,暴力是过不了的,在n = 150000处超时。我看了一下提示,hint 4提示了筛法:然后是hint5,6,7,8说的都是对循环条件的处理:如果要实现筛法,需要一个O(n)的数组来存...原创 2018-07-19 16:08:31 · 930 阅读 · 0 评论 -
LeetCode: 384. 打乱数组(Java & Python)
题目:打乱一个没有重复元素的数组。示例:// 以数字集合 1, 2 和 3 初始化数组。int[] nums = {1,2,3};Solution solution = new Solution(nums);// 打乱数组 [1,2,3] 并返回结果。任何 [1,2,3]的排列返回的概率应该相同。solution.shuffle();// 重设数组到它的初始状态[1,2...原创 2018-07-18 16:40:00 · 1238 阅读 · 0 评论 -
LeetCode: 28.实现strStr()(C++)
题目:实现 strStr() 函数。给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。 示例 1:输入: haystack = "hello", needle = "ll"输出: 2示例 2:输入: haystack = "aaaaa",...原创 2018-07-24 09:41:08 · 789 阅读 · 1 评论 -
LeetCode:657 机器人能否返回原点(Java & Python)
题目:初始位置 (0, 0) 处有一个机器人。给出它的一系列动作,判断这个机器人的移动路线是否形成一个圆圈,换言之就是判断它是否会移回到原来的位置。移动顺序由一个字符串表示。每一个动作都是由一个字符来表示的。机器人有效的动作有R(右),L(左),U(上)和D(下)。输出应为true 或 false,表示机器人移动路线是否成圈。示例 1:输入: "UD"输出: true...原创 2018-07-12 16:03:47 · 317 阅读 · 0 评论 -
*LeetCode的开端:1. 两数之和(Java & Python)
经典的OJ题,放假了,刷这题作为开始。题目:给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。示例:给定 nums = [2, 7, 11, 15], target = 9因为 nums[0] + nums[1] = 2 + 7 = 9所以返回 [0, 1]我的解答:第一个想到的自然是暴力解...原创 2018-07-12 16:00:10 · 1583 阅读 · 1 评论 -
LeetCode:70. 爬楼梯(Java & Python)
题目:假设你正在爬楼梯。需要n步你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?注意:给定n是一个正整数。示例 1:输入: 2输出: 2解释: 有两种方法可以爬到楼顶。1. 1 步 + 1 步2. 2 步示例 2:输入: 3输出: 3解释: 有三种方法可以爬到楼顶。1. 1 步 + 1 步 + 1 步...原创 2018-07-17 14:49:30 · 1234 阅读 · 0 评论 -
LeetCode: 155. 最小栈(C++)
题目:设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈。push(x) -- 将元素 x 推入栈中。 pop() -- 删除栈顶的元素。 top() -- 获取栈顶元素。 getMin() -- 检索栈中的最小元素。示例:MinStack minStack = new MinStack();minStack.push(-2);minStac...原创 2018-07-29 10:17:19 · 2121 阅读 · 1 评论 -
LeetCode: 98. 验证二叉搜索树(C++)
题目:给定一个二叉树,判断其是否是一个有效的二叉搜索树。一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。 节点的右子树只包含大于当前节点的数。 所有左子树和右子树自身必须也是二叉搜索树。示例 1:输入: 2 / \ 1 3输出: true示例 2:输入: 5 / \ 1 4 / \ ...原创 2018-07-26 16:48:43 · 872 阅读 · 0 评论