【LeetCode笔记】53. 最大子序和(Java、动态规划)

文章目录

  • 题目描述
  • 代码 & 思路

题目描述

  • 经典题目了,多种解法(不过目前只学了一种,暴力不算)
    在这里插入图片描述

代码 & 思路

这块基本上算是写给自己看的了。。写得不好,如果想学这种方法最好还是去leetcode题解看。

  • sum = num:因为在上一次循环结尾,就已经取得了i-1结尾的子序的最大和,也就是[0, i-1]的任务已经完成了,继续使用无意义,因为sum < 0的情况下,只会对后面的子序带来负增益
  • 例子1:1,2 ,-4,1, -1,首先取到最大值【1,2】,然后【1,2,-4】时,【1,2,-4】已经无意义,接下来只要对剩下的【1,-1】进行判断即可。
    原因:首先从2开始的【2,-4】肯定不如之前的【1,2,-4】大,因为之所以2之前的【1】能连上2,就是因为【1】这一部分是不小于0的,有正增益。然后之所以不能取【2,-4】再连上后面的【1,-1】,是因为这肯定还不如【1,2,-4】,原理基本上同上(前面的起码还是正增益,舍掉了得比现在还小)。
class Solution {public int maxSubArray(int[] nums) {int ans = nums[0];int sum = 0;// 使用动态规划:时间复杂度O(n)for(int num : nums){// 取值,然后舍掉(因为不如不加)if(sum < 0){sum = num;}// 否则继续下去else{sum += num;}ans = Math.max(ans,sum);}return ans;}
}
  • 时间复杂度O(n),一次遍历结束
  • 空间复杂度O(1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504596.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

matlab画三维实心圆柱体,怎样用matlab画水平实心圆柱体,已知圆柱体的半径和高度(悬? 爱问知识人...

clear allr1;%圆柱半径n100;%设置多少个边逼近圆h5;%圆柱高[x,y,z]cylinder(r,n);%生成标准的100个面的圆柱数据&#xff0c;半径为r&#xff0c;高为1&#xff0c;底面圆心0&#xff0c;0&#xff1b;z1[z(1,:);z(2,:) h-1];%圆柱高增高&#xff0c;变为高h%为变成实心封顶添加…

【LeetCode笔记(水)】s = null 与 s.length() == 0

来水一篇博客&#xff0c;加固一下印象 在刷题过程&#xff0c;经常要考虑输入值为空的情况。其中&#xff0c;输入值为字符串、数组或者链表时&#xff0c;有两种需要判断的情况&#xff0c;此处以String s 为例 s null; 也就是s还没有占用存储空间。s.length 0; s占用存储…

php umount强制,linux中mount/umount命令的基本用法及开机自动挂载方法

本文介绍了linux中mount/umount命令的基本用法及开机自动挂载&#xff0c;具体方法如下&#xff1a;mount命令格式如下&#xff1a;格式&#xff1a;mount [-参数] [设备名称] [挂载点]其中常用的参数有&#xff1a;-a 安装在/etc/fstab文件中类出的所有文件系统。-f 伪装mount…

【LeetCode笔记】32. 最长有效括号(Java、动态规划、栈、字符串)

文章目录题目描述代码 & 解析1. 栈做法2. 动态规划题目描述 &#xff08;括号题真的好烦人&#xff09;讲道理&#xff0c;题目一看&#xff0c;大概率就是用dp做 代码 & 解析 1. 栈做法 这个做法我没实际写&#xff0c;但是感觉很厉害&#xff0c;就记录一下。我…

php分页类smary,Smarty分页实现方法完整实例

这篇文章主要介绍了Smarty分页实现方法,涉及基于Smarty的数据库查询、分页相关计算与模板操作技巧,需要的朋友可以参考下本文实例讲述了Smarty分页实现方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;首先是PHP文件部分&#xff1a;require("include.php&quo…

【LeetCode笔记】33. 搜索螺旋排序数组(Java、二分)

文章目录题目描述思路 & 代码题目描述 有序数组中搜索值&#xff0c;显然用二分旋转带来的影响并不大&#xff0c;只要多加几个判断&#xff0c;改改范围就行。 思路 & 代码 首先找出两部分升序子数组的分割点k然后再判断需要在哪个子数组进行二分&#xff0c;并进…

301.inc.php,DeDeCMS默认首页及WWW域的301跳转

你是否留心过&#xff1a;通过域名访问网站首页时&#xff0c;网页返回Http状态码是什么&#xff1f;甚至访问内页时&#xff0c;Http状态码又是什么吗&#xff1f;大多数人可能会想当然的认为首页返回的肯定是200&#xff0c;因为我们很容易观察到首页能否可以正常打开以及URL…

【LeetCode笔记】39. 组合总和(Java、DFS回溯、队列)

文章目录题目描述思路 & 代码题目描述 讲道理&#xff0c;像这种找可行集合解的问题&#xff0c;基本上都可以通过回溯 剪枝来做 思路 & 代码 sort()用于优化&#xff0c;多一个剪枝判断&#xff0c;其实也可以不写双向队列deque&#xff1a;第一次用&#xff0c;…

【LeetCode笔记】34. 在排序数组中查找元素的第一个和最后一个位置(Java、二分)

文章目录题目描述思路 & 代码1. 暴力法2. 二分法3. 二分法——简略版题目描述 老套路了&#xff0c;有序找元素&#xff0c;直接冲二分思路是不难想&#xff0c;就是边界条件限制条件有点恶心&#xff0c;时不时爆个栈 思路 & 代码 1. 暴力法 一次遍历找到left&am…

【LeetCode笔记】42. 接雨水(Java、动态规划)

文章目录题目描述代码 & 思路方法一&#xff1a;暴力法方法二&#xff1a;动态规划题目描述 当前列有水判断&#xff1a;左边最高列 & 右边最高列的短板不小于当前列 代码 & 思路 方法一&#xff1a;暴力法 对于每一列O(n)&#xff0c;都找出左边最高列O(n)&a…

【LeetCode笔记】46. 全排列(Java、DFS回溯、队列)

文章目录题目描述代码 & 思路题目描述 老简单了&#xff0c;一眼就是用visited数组记录出现过的数字&#xff0c;依次基础上进行回溯即可和前面的题目很像&#xff0c;用队列结合回溯使用 代码 & 思路 class Solution {public List<List<Integer>> per…

【LeetCode笔记】48. 旋转图像(Java、矩阵、偏数学、原地算法)

文章目录题目描述代码 & 思路题目描述 矩阵题&#xff0c;一眼就感觉很烦&#xff0c;直接看了题解 因为要求原地旋转&#xff0c;所以只能用temp来做当然&#xff0c;我们还是要回顾一下矩阵转置的&#xff0c;看看和这道题有啥不同&#xff0c;说不定就能用上呢。好的&a…

【LeetCode笔记】49. 字母异位词分组(Java、字符串、哈希表)

文章目录题目描述代码 & 思路题目描述 考虑&#xff1a;如何把字母相同、排列不同的字符串组合成一个相同的、独一无二的东西&#xff1f;尝试1&#xff1a;使用ascii的和&#xff08;不行&#xff0c;虽然说确实相同&#xff0c;但是独一无二不满足&#xff09;尝试2&…

【LeetCode笔记】55. 跳跃游戏(Java、贪心法)

文章目录题目描述解法 & 思路题目描述 可以用动态规划来做&#xff0c;dp[i]代表以第i个下标做起点&#xff0c;可以到达的最远的地方&#xff0c;从后往前走&#xff0c;最后dp[0] > len-1说明可达。不过我的dp相对于贪心法慢了不少(400ms&#xff09; 解法 & 思…

【LeetCode笔记】56. 合并区间(Java、排序)

文章目录题目描述代码 & 思路更新版 2.0题目描述 重叠区间&#xff1a;需要有重叠判断注意&#xff1a;题目并没有说集合间有序&#xff0c;因此要先做一个排序&#xff0c;以左下标为排序值&#xff08;否则会出错 代码 & 思路 经过排序后&#xff0c;只需要循环一…

【LeetCode笔记】62. 不同路径(Java、动态规划)

文章目录题目描述代码 & 思路更新 2.0 版本题目描述 一眼bfs&#xff0c;不过超时了。。。好&#xff0c;那么我们就用动态规划来做&#xff01; 代码 & 思路 和走迷宫差不多&#xff0c;从终点往起点走。dp[i][j]代表(i&#xff0c;j&#xff09;到终点的可行路径…

php创建windos用户,window_Win7系统创建及开启隐藏账户图文教程,  在电脑操作中有时候因为 - phpStudy...

Win7系统创建及开启隐藏账户图文教程在电脑操作中有时候因为个人需要就会在电脑上创建一个隐藏账户&#xff0c;隐藏账户就是在控制面板与开机选择中看不见的账户。它可以用输账号密码的方式进入也有着管理员权限。有了隐藏账户别人不会发现&#xff0c;即使别人设了密码也可以…

【LeetCode笔记】64. 最小路径和(Java、动态规划)

文章目录题目描述代码 & 题目描述题目描述 动态规划&#xff0c;dp[][]都可以直接用grid[][]。空间复杂度O(1) 代码 & 题目描述 dp[i[j] grid[i][j] (grid[i-1][j] grid[i][j-1])&#xff0c;注意边界判断时间复杂度O(m*n) class Solution {public int minPath…

php中文本设置随机颜色,php 产生随机整数,随机字符串,随机颜色等类用法

/*** 产生随机整数&#xff0c;随机字符串&#xff0c;随机颜色等** param* arrange (512.笔记) jb51.cc**/public static class RandomHelper{private static Random randomSeed new Random();/// /// Generates a random string with the given length/// /// Size of the s…

【LeetCode笔记】70. 爬楼梯(Java、动态规划)

文章目录题目描述代码 & 思路1. 动态规划 O(n)、O(n)2. 动态规划 O(n)、O(1)题目描述 DP 入门题了属于是 代码 & 思路 1. 动态规划 O(n)、O(n) dp[i]&#xff1a;可以到第 i 阶的方法有dp[i]种&#xff0c;所以dp[n]就是ans&#xff08;注意dp.length n1&#xf…