【算法题】最大子序和

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

子数组 是数组中的一个连续部分。

示例 1:
输入: nums = [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6 。

示例 2:
输入: nums = [1] 输出: 1

示例 3:
输入: nums = [5,4,-1,7,8] 输出: 23

  • 提示:
    1 <= nums.length <= 105
    -104 <= nums[i] <= 104

解法(js):

1、暴力解法遍历
求出所有子序列的和,然后从中挑选出最大的。

    const nums = [-2, 1, -3, 4, -1, 2, 1, -5, 4];const maxSub = (arr) => {let maxSum = arr[0];for (let i = 0; i < arr.length; i++) {let sum = 0;for (let j = i; j < arr.length; j++) {sum += arr[j];maxSum = Math.max(maxSum, sum);}}console.log(maxSum);return maxSum;};

2、动态规划
对于最大子序和问题的状态转移方程:

dp[i] = max(nums[i], dp[i-1] + nums[i])

为了理解这个方程是如何确保我们总能获得最大分数的和,我们需要领会动态规划这种算法设计方法的核心思想:最优子结构。

最优子结构是什么意思呢?

在动态规划中,最优子结构意味着一个问题的最优解包含着其子问题的最优解。换句话说,你可以通过组合子问题的最优解来得到整个问题的最优解。

在最大子序和问题中,如果你知道了以nums[i-1]结尾的最大分数和(假设叫它最优子结果),并且现在你面对的新选择是nums[i],那么问题就变成了:

如果这个最优子结果是一个负数,加上nums[i]后总和只会变小,所以我们不如直接从nums[i]开始算起。
如果这个最优子结果是一个正数,那么加上nums[i]后总和会增加,所以我们维持当前子序列,将nums[i]纳入进来。

现在回到状态转移方程。通过持续地更新dp[i],我们总是保持了以nums[i]结尾的最大分数和,对于每一个i:

当你选择nums[i]时,你实际上是重置计数器,从当前这个点开始重新计算子序列(因为你认为之前的序列和对你现在是没帮助的,可能是因为它们是负数)。
当你选择dp[i-1] + nums[i]时,你实际上是选择连续的子序列,并且你相信通过保留之前的序列,新的总和会更大。
该方程确保了你总是取了当前罗列所有可能性中的最大值。通过从左到右遍历数组,你保持了每个子序列的最优解,也因此在每个步骤中,都基于之前的最优解做出了决策。

最终,遍历完成后,数组中包含的dp[i]值中的最大值,就是全局的最大子序和。程序实际上会使用一个变量来记录这个过程中遇到的最大值,因此你不必存储所有的dp[i],只需保持当前的子序列最大和即可。

这样,你可以有信心在完成遍历之后,得到的一定是最大的子序和。这就是动态规划设计方法强大的地方,它确保了你在整个过程中每一步都是基于最优结果做出的选择。

js代码:

const maxSubArrSum = (nums)=>{const maxAns = arr[0];const pre = arr[0]nums.forEach((i) =>{pre = Math.max(pre+i,i);   // 如果pre+i < i 说明之前的结果肯定是负数,不如从新的子集开始算maxAns = Math.max(pre,maxAns);} )console.log(maxAns);return maxAns;
}

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

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

相关文章

R语言数据分析案例39-合肥市AQI聚类和多元线性回归

一、研究背景 随着全球工业化和城市化的迅速发展&#xff0c;空气污染问题日益凸显&#xff0c;已成为影响人类健康和环境质量的重大挑战。空气污染不仅会引发呼吸系统、心血管系统等多种疾病&#xff0c;还会对生态系统造成不可逆转的损害。因此&#xff0c;空气质量的监测和…

MySQL高阶:事务和并发

事务和并发 1. 事务创建事务 2. 并发和锁定并发问题 3. 事务隔离等级3.1 读取未提交隔离级别3.2 读取已提交隔离级别3.3 重复读取隔离级别3.4 序列化隔离级别 4. 死锁 1. 事务 事务&#xff08;trasaction&#xff09;是完成一个完整事件的一系列SQL语句。这一组SQL语句是一条…

fastapi自定义中间件

fastapi自定义中间件 1、自定义中间件类 from fastapi import Request from starlette.middleware.base import BaseHTTPMiddlewareclass MyMiddleware(BaseHTTPMiddleware):def __init__(self, app,*args, **kwargs):super().__init__(app,*args, **kwargs)async def dispat…

Head First设计模式中的典型设计模式解析与案例分析

Head First设计模式中的典型设计模式解析与案例分析 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 《Head First设计模式》是一本广受欢迎的书籍&#xff0c…

经典小游戏(一)C实现——三子棋

switch(input){case 1:printf("三子棋\n");//这里先测试是否会执行成功break;case 0:printf("退出游戏\n");break;default :printf("选择错误&#xff0c;请重新选择!\n");break;}}while(input);//直到输入的结果为假&#xff0c;循环才会结束} …

go Channel原理 (二)

Channel 设计原理 不要通过共享内存的方式进行通信&#xff0c;而是应该通过通信的方式共享内存。 在主流编程语言中&#xff0c;多个线程传递数据的方式一般都是共享内存。 Go 可以使用共享内存加互斥锁进行通信&#xff0c;同时也提供了一种不同的并发模型&#xff0c;即通…

error: Sandbox: rsync.samba in Xcode project

在Targets 的 Build Settings 搜索&#xff1a;User script sandboxing 设置为NO

python课程设计作业-TCP客户端-服务端通信

说明文档 目录 小组成员分工 作品功能介绍 使用的工具和方法 设计的步骤 课程设计中遇到的问题 结论 1. 小组成员分工 本次课程设计由以下小组成员完成&#xff1a; xxx 2. 作品功能介绍 本次课程设计的作品是一个简单的基于 TCP 协议的客户端-服务端通信示例。通过这个示…

【SpringBoot Web框架实战教程】06 SpringBoot 整合 Druid

不积跬步&#xff0c;无以至千里&#xff1b;不积小流&#xff0c;无以成江海。大家好&#xff0c;我是闲鹤&#xff0c;微信&#xff1a;xxh_1459&#xff0c;十多年开发、架构经验&#xff0c;先后在华为、迅雷服役过&#xff0c;也在高校从事教学3年&#xff1b;目前已创业了…

阿里云centos7.9 挂载数据盘到 www目录

一、让系统显示中文 参考&#xff1a;centos7 怎么让命令行显示中文&#xff08;英文-&#xff1e;中文&#xff09;_如何在命令行中显示中文-CSDN博客 1、输入命令&#xff1a;locale -a |grep "zh_CN" 可以看到已经存在了中文包 2、输入命令&#xff1a;sudo vi…

AGPT•intelligence:带你领略全新量化交易的风采

随着金融科技的快速发展&#xff0c;量化交易已经成为了投资领域的热门话题。越来越多的投资者开始关注和使用量化交易软件来进行投资决策。在市场上有许多量化交易软件可供选择。 Delaek&#xff0c;是一位资深的金融科技专家&#xff0c;在 2020年成立一家专注于数字资产量化…

第一后裔延迟高怎么办?快速降低第一后裔延迟

第一后裔/The First Descendant一款射击游戏&#xff0c;融合了刷宝、角色扮演、团队合作、剧情等元素&#xff0c;让每个玩家都能在自己的角度上&#xff0c;找到切入点&#xff0c;并不断地成长&#xff0c;一步步解开后裔身上隐藏的秘密。近期该作正式上线&#xff0c;很多玩…

获取微信公众号所有订阅用户,并批量获取用户基本信息

获取微信公众号所有订阅用户&#xff0c;并批量获取用户基本信息 public void syncSubscribe() {String appId ApiConstants.PUBLIC_ACCOUNT_APP_ID;// 所有订阅用户List<String> openIdList getUserList(appId);// 一个批次只能查100条数据&#xff0c;将List按100的长…

vue项目创建+eslint+Prettier+git提交规范(commitizen+hooks+husk)

# 步骤 1、使用 vue-cli 创建项目 这一小节我们需要创建一个 vue3 的项目&#xff0c;而创建项目的方式依然是通过 vue-cli 进行创建。 不过这里有一点大家需要注意&#xff0c;因为我们需要使用最新的模板&#xff0c;所以请保证你的 vue-cli 的版本在 4.5.13 以上&#xff…

Debian linux忘记root密码如何重置

重启电脑, 到下图再按 e 键 在页面中可以看到有个ro的行&#xff0c;在ro行的尾部&#xff0c;添加 rw init/bin/bas 3. ctrl X 启动系统&#xff0c;最后会进入命令行模式 4. 重设root密码&#xff0c;输入命令 passwd root&#xff0c;按照提示输入新密码并确认 5. 重启系…

基于Python的自动化测试框架-Pytest总结-第一弹基础

Pytest总结第一弹基础 入门知识点安装pytest运行pytest测试用例发现规则执行方式命令行执行参数 配置发现规则 如何编写测试Case基础案例断言语句的使用pytest.fail() 和 Exceptions自定义断言函数异常测试测试类形式 pytest的Fixture使用Fixture入门案例使用fixture的Setup、T…

昇思25天学习打卡营第8天|模型训练

昇思25天学习打卡营第8天|模型训练 前言模型训练构建数据集定义神经网络模型定义超参、损失函数和优化器超参损失函数优化器 训练与评估 个人任务打卡&#xff08;读者请忽略&#xff09;个人理解与总结 前言 非常感谢华为昇思大模型平台和CSDN邀请体验昇思大模型&#xff01;从…

linux中如何启动python虚拟环境

找到python虚拟环境所在目录 执行下面的命令即可 source auth_python/bin/activate

2024自然语言处理期末回忆

2024.6.19考 总体来说&#xff0c;很离谱&#xff0c;那么多ppt&#xff0c;考之前以为肯定会考算法&#xff0c;看了好久的算法&#xff0c;结果考了很多概念题。 就是说&#xff0c;这门课很抽象&#xff0c;能不选就别选了。 1.&#xff08;1&#xff09;什么是预训练词向…

【遇坑笔记】Node.js 开发环境与配置 Visual Studio Code

【遇坑笔记】Node.js 开发环境与配置 Visual Studio Code 前言node.js开发环境配置解决pnpm 不是内部或外部命令的问题&#xff08;pnpm安装教程&#xff09; 解决 pnpm : 无法加载文件 C:\Program Files\nodejs\pnpm.ps1&#xff0c;因为在此系统上禁止运行脚本。 前言 最近部…