动态规划
立志进大厂的一个菜比
这个作者很懒,什么都没留下…
展开
-
leetcode 91 解码方法
‘A’ -> 1‘B’ -> 2…‘Z’ -> 26给定一个只包含数字的非空字符串,请计算解码方法的总数。题目数据保证答案肯定是一个 32 位的整数。示例 1:输入:“12”输出:2解释:它可以解码为 “AB”(1 2)或者 “L”(12)。示例 2:输入:“226”输出:3解释:它可以解码为 “BZ” (2 26), “VF” (22 6), 或者 “BBF” (2 2 6) 。示例 3:输入:s = “0”输出:0示例 4:输入:s = “1”输出原创 2020-10-13 15:51:13 · 121 阅读 · 0 评论 -
leetcode 42 剑值offer42 连续子数组的最大和
输入一个整型数组,数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为O(n)。示例1:输入: nums = [-2,1,-3,4,-1,2,1,-5,4]输出: 6解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。//只要求结果,这种一般都是dpclass Solution { public int maxSubArray(int[] nums) { int n=nums.length; int[] dp=ne原创 2020-10-04 21:01:07 · 86 阅读 · 0 评论 -
leetcode 143 整数拆分
给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化。 返回你可以获得的最大乘积。示例 1:输入: 2输出: 1解释: 2 = 1 + 1, 1 × 1 = 1。示例 2:输入: 10输出: 36解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。因为n可以拆分成两个数,也可以拆分多个数。 拆分成两个数的时候乘积就是i * (n - i),也可以选择继续拆分:integerBreak(n - i)就是将n - i继续拆分的结果,但是我们并不知道种哪拆原创 2020-10-04 12:12:08 · 175 阅读 · 0 评论 -
leetcode 152 乘积最大子数组
给你一个整数数组 nums ,请你找出数组中乘积最大的连续子数组(该子数组中至少包含一个数字),并返回该子数组所对应的乘积。示例 1:输入: [2,3,-2,4]输出: 6解释: 子数组 [2,3] 有最大乘积 6。示例 2:输入: [-2,0,-1]输出: 0解释: 结果不能为 2, 因为 [-2,-1] 不是子数组。class Solution { //max,min表示有nums[i]参与的连续子数组的最大值和最小值 public int maxProduct(int原创 2020-10-03 14:57:52 · 89 阅读 · 0 评论 -
leetcode 32 最长有效括号
给定一个只包含 ‘(’ 和 ‘)’ 的字符串,找出最长的包含有效括号的子串的长度。示例 1:输入: “(()”输出: 2解释: 最长有效括号子串为 “()”示例 2:输入: “)()())”输出: 4解释: 最长有效括号子串为 “()()”有效括号的特性,就是长度一定是偶数,并且在任何位置左括号的数量都是大于等于右括号的数量的,如果在任何位置右括号大于左括号的数量,那么说明这个组成的括号是无效的。根据这个特性我们来看下代码 public int longestValidParent原创 2020-10-03 13:37:18 · 106 阅读 · 0 评论 -
leetcode 面试题17.16.按摩师
一个有名的按摩师会收到源源不断的预约请求,每个预约都可以选择接或不接。在每次预约服务之间要有休息时间,因此她不能接受相邻的预约。给定一个预约请求序列,替按摩师找到最优的预约集合(总预约时间最长),返回总的分钟数。注意:本题相对原题稍作改动示例 1:输入: [1,2,3,1]输出: 4解释: 选择 1 号预约和 3 号预约,总时长 = 1 + 3 = 4。示例 2:输入: [2,7,9,3,1]输出: 12解释: 选择 1 号预约、 3 号预约和 5 号预约,总时长 = 2 + 9 + 1原创 2020-10-03 11:42:59 · 238 阅读 · 0 评论 -
leetcode 5最长回文字串
给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。示例 1:输入: “babad”输出: “bab”注意: “aba” 也是一个有效答案。示例 2:输入: “cbbd”输出: “bb”第一遍的暴力搜索,961msclass Solution { char[] ch; int n; public String longestPalindrome(String s) { ch=s.toCharArray();原创 2020-10-01 23:13:11 · 129 阅读 · 0 评论 -
leetcode 300 最长上升序列
给定一个无序的整数数组,找到其中最长上升子序列的长度。示例:输入: [10,9,2,5,3,7,101,18]输出: 4解释: 最长的上升子序列是 [2,3,7,101],它的长度是 4。二分查找法:新建一个数组,然后第一个数先放进去,然后第二个数和第一个数比较,如果说大于第一个数,那么就接在他后面,如果小于第一个数,那么就替换,一般的,如果有i个数,那么每进来一个新的数,都要用二分查找法来得知要替换在哪个位置的数。因为有个for循环,所以是O(N),在加上循环里有个二分查找,所以最后是O(Nl原创 2020-10-01 22:02:31 · 65 阅读 · 0 评论 -
leetcode 63 不同路径||
一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” )。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为“Finish”)。现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?输入:[[0,0,0],[0,1,0],[0,0,0]]输出: 2解释:3x3 网格的正中间有一个障碍物。从左上角到右下角一共有 2 条不同的路径:向右 -> 向右 -> 向下 -> 向下向下 -> 向下原创 2020-09-30 19:59:46 · 135 阅读 · 0 评论 -
leetcode 322 零钱兑换
注意第一次搜索到了答案不一定是最优的,之后还要继续搜索if((amount-sum)/coins[i]+count>=ans) break;//关于count的剪枝操作,属于优化操作,即剩下的重量全部装coins[i]的个数再加上已经的count必须小于ans,这里的ans是已经搜索过的答案。if(sum+coins[i]<=amount)//关于sum的剪枝操作,属于必须操作class Solution { int[] coins; int amount; int原创 2020-09-30 14:29:00 · 216 阅读 · 0 评论 -
leetcode 120 三角形最小路径
给定一个三角形,找出自顶向下的最小路径和。每一步只能移动到下一行中相邻的结点上。相邻的结点 在这里指的是 下标 与 上一层结点下标 相同或者等于 上一层结点下标 + 1 的两个结点。例如,给定三角形:[[2],[3,4],[6,5,7],[4,1,8,3]]自顶向下的最小路径和为 11(即,2 + 3 + 5 + 1 = 11)。注意:既然是一条通路,那么就应该想到是既可以自底向上,也可以自顶向下。自顶向下,从右往左,使用O(N)的空间class Solution { pub原创 2020-09-29 23:15:35 · 83 阅读 · 0 评论 -
leetcode 62 不同路径
一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” )。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为“Finish”)。问总共有多少条不同的路径?示例 1:输入: m = 3, n = 2输出: 3解释:从左上角开始,总共有 3 条路径可以到达右下角。向右 -> 向右 -> 向下向右 -> 向下 -> 向右向下 -> 向右 -> 向右示例 2:输入: m = 7, n = 3输原创 2020-09-29 15:37:26 · 89 阅读 · 0 评论 -
leetcode 64 最小路径和
给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。说明:每次只能向下或者向右移动一步。示例:输入:[[1,3,1],[1,5,1],[4,2,1]]输出: 7解释: 因为路径 1→3→1→1→1 的总和最小。DFS又超时了class Solution { int ans=0x7fffffff; public int minPathSum(int[][] grid) { dfs(0,0,grid,0)原创 2020-09-28 23:48:10 · 157 阅读 · 0 评论 -
leetcode 198 打家劫舍
你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。示例 1:输入:[1,2,3,1]输出:4解释:偷窃 1 号房屋 (金额 = 1) ,然后偷窃 3 号房屋 (金额 = 3)。偷窃到的最高金额 = 1 + 3 = 4 。示例 2:输入:[2,7,9,3,原创 2020-09-28 20:28:32 · 74 阅读 · 0 评论 -
leetcode 70 爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?注意:给定 n 是一个正整数。示例 1:输入: 2输出: 2解释: 有两种方法可以爬到楼顶。1 阶 + 1 阶2 阶示例 2:输入: 3输出: 3解释: 有三种方法可以爬到楼顶。1 阶 + 1 阶 + 1 阶1 阶 + 2 阶2 阶 + 1 阶回溯直接超时,n=42就超了,参考代码:class Solution { int n; int原创 2020-09-27 23:27:31 · 113 阅读 · 0 评论