LeetCode 1043. 分隔数组以得到最大和

news2024/10/6 16:28:08

原题链接:1043. 分隔数组以得到最大和

给你一个整数数组 arr,请你将该数组分隔为长度 最多 为 k 的一些(连续)子数组。分隔完成后,每个子数组的中的所有值都会变为该子数组中的最大值。

返回将数组分隔变换后能够得到的元素最大和。本题所用到的测试用例会确保答案是一个 32 位整数。

示例 1:

输入:arr = [1,15,7,9,2,5,10], k = 3
输出:84
解释:数组变为 [15,15,15,9,10,10,10]

示例 2:

输入:arr = [1,4,1,5,7,3,6,1,9,9,3], k = 4
输出:83

示例 3:

输入:arr = [1], k = 1
输出:1

思路:先读懂题。题目意思是把给定的数组以最大长度为k划分子数组,且划分完之后子数组的值都会变为当前子数组中的最大值,要返回划分完之后的数组元素最大和。

那么这道题就变成了一个如何划分数组的问题,长度为l的数组,假设当前的位置在i,划分的子数组最大长度为k,那么我们先要看到就是“i-k”到“i-1”这个范围里,因为最大长度为k,所以是i-k,之后看[i-k, i-1]里哪一个最大,即枚举j,而枚举j时,j之前的都可以看作已经完成的,且结果已经确定,那么j+1到i这一段就可以看作是新的一段,在新的这一段里继续进行枚举。

这样就把一个大问题拆分为一个个子问题,而且这些子问题的结果都是可以记录的,减少重复计算量。之后写出状态转移方程 d[i] = max(d[i], d[j] + maxValue * (i - j));

class Solution {
public:
    using ll = long long;
    int maxSumAfterPartitioning(vector<int>& arr, int k) {
        int n = arr.size(); // 拿到数组大小
        vector<int> d(n + 1); // 搞一个d容器存结果
        for (int i = 1; i <= n; i++) { // 从i=1开始循环
            int maxValue = arr[i - 1]; // 先给max一个初始值,即arr[0]先为最大值
            for (int j = i - 1; j >= 0 && j >= i - k; j--) { //注意判断条件和j的初始值为i-1,判断条件是在j大于等于0时且j大于等于i-k,即我们提到的j在[i-k, i-1]的范围内进行枚举。
                d[i] = max(d[i], d[j] + maxValue * (i - j)); //状态转移方程,更新d[i]
                if (j > 0) {
                    maxValue = max(maxValue, arr[j - 1]);
                }
            }
        }
        return d[n];
    }
};

递归是从n到0,动态规划是从0到n。

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

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

相关文章

巧用千寻位置GNSS软件| 线路施工放样应用技巧

线路施工放样主要是解决线路工程和水利工程施工中&#xff0c;线路及渠道中线和边坡施工放样编辑的专用程序。千寻位置GNSS软件中完成线路施工放样可按照下述步骤操作。 点击【测量】->【线路施工放样】&#xff0c;选择一条线路放样&#xff0c;如图 5.6-1所示。 图 5.6-1…

跟姥爷深度学习4 从数学计算看神经网络

一、前言 我们前面简单的做了一个气温预测&#xff0c;经过反复调试&#xff0c;效果还不错。实际上在这个方向上我们还可以更进一步优化&#xff0c;但因为我们是学习嘛&#xff0c;主要还是看广度而不是深度。考虑到后面要开始学习卷积网络&#xff0c;我们必须把更基础的内…

打印流,Properties类

打印流只有输出流&#xff0c;没有输入流 package com.hspedu.printstream;import java.io.IOException; import java.io.PrintStream;/*** author 韩顺平* version 1.0* 演示PrintStream &#xff08;字节打印流/输出流&#xff09;*/ public class PrintStream_ {public stat…

网络安全-网站漏洞扫描器

网络安全-网站漏洞扫描器 网站漏洞扫描器是用来扫描对方网站可能存在哪些漏洞的工具&#xff0c;我们可以借助网站漏洞扫描器来当作辅助作用去检测对方网站的漏洞。下面我们来介绍一款常用、好用的漏洞扫描器–AWVS。 AWVS 先说缺点-这玩意简称漏扫&#xff0c;你一旦发送&a…

IPSEC相关知识点

1.什么是数据认证&#xff0c;有什么作用&#xff0c;有哪些实现的技术手段? 数字认证证书它是以数字证书为核心的加密技术可以对网络上传输的信息进行加密和解密、数字签名和签名验证&#xff0c;确保网上传递信息的安全性、完整性。 使用了数字证书&#xff0c;即使您发送的…

(PCB系列七)PCB差分信号布线及其要点

1、差分信号的定义 差分传输是一种信号传输的技术&#xff0c;区别于传统的一根信号线一根地线的做法&#xff0c;差分传输在这两根线上都传输信号&#xff0c;这两个信号的振幅相同&#xff0c;相位相反。在这两根线上的传输的信号就是差分信号。信号接收端比较这两个电压的差…

不要老盯着ChatGPT,这几家公司的产品同样不容小觑

Adept.ai 2022 年成立&#xff0c;致力于一款能够代替人类使用电脑、操控软件的AI助手&#xff0c;旗下模型 ACT-1 还处于雏形阶段&#xff0c;但根据官方示例&#xff0c;已经可以完成通过自然语言指令完成特定的任务。公司创始人曾任OpenAI的工程副总裁&#xff0c;后来进入谷…

前端开发APP应该采取什么框架?

近十年&#xff0c;随移动网络在人们生活中的不断渗透以及线上服务需求的不断提升&#xff0c;人们对于桌面应用、APP、小程序、物联网终端设备等的需求不断提升。据公开数据显示&#xff0c;2022年&#xff0c;小程序数量已超550万&#xff1b;工信部数据显示&#xff0c;截止…

会议回顾!2023机器视觉在线研讨会圆满结束

4月20日下午&#xff0c;持续两小时的“融合生态&#xff0c;让制造与视俱进”2023机器视觉在线研讨会圆满结束&#xff0c;此次会议联合机器视觉产业链上中下游厂商&#xff0c;共同分享工业机器视觉领域最新技术和应用案例&#xff0c;专题讲解与观众问答相互交织&#xff0c…

OpenAI API调用

上次简单写了一篇对ChatGPT的一些看法&#xff0c;最近想深入研究一下。 极客时间上有个课程《AI大模型之美》&#xff0c;看了一下还可以。当做入门是不错的&#xff0c;但还是有很多细节可以打磨&#xff0c;不过毕竟是在风口上的课&#xff0c;也能接受。 本次演示如何调用…

【小知识点总结】Java中的split函数的用法(二)

一、String.split()函数有两种形式 split(String regex) 会默认忽略字符串后面的分隔符split(String regex,int limit) regex:可以是字符串或者正则表达式 limit:可以限制返回的数组的元素个数&#xff0c;当其值为-1时&#xff0c;表示任意大小 // s.split("-")会忽…

阿赵的MaxScript学习笔记分享十五《MaxScript界面的进阶应用》

MaxScript学习笔记目录 大家好&#xff0c;我是阿赵&#xff0c;之前介绍过MaxScript的各种UI控件的用法&#xff0c;这次介绍一些稍微复杂一点的用法。 一、例子介绍 这次要做的例子&#xff0c;有一部分是使用了dotNet的UI控件&#xff0c;一部分是MaxScript自带的UI用法&a…

理解Vuex【Vue】

5. vuex 5.1 理解vuex 5.1.1 vuex是什么 概念&#xff1a;专门在Vue中实现集中式状态&#xff08;数据&#xff09;管理的一个Vue插件&#xff0c;对vue应用中多个组件的共享状态进行集中式的管理&#xff08;读/写&#xff09;&#xff0c;也是一种组件间通信的方式&#x…

AI风范,院士点赞丨北京人工智能峰会暨AI金雁奖颁奖典礼成功举办,实在智能再获AI金雁奖

4月14日&#xff0c;由中国电子商会人工智能委员会主办&#xff0c;中国创业者俱乐部、北京集智未来人工智能产业创新基地联合主办的“2023北京人工智能峰会暨AI金雁奖颁奖典礼”举行&#xff0c;汇聚了人工智能各领域的产学研专家、院士、人工智能企业代表近300人&#xff0c;…

Jenkins自动拉取SVN源代码构建打包vue前端项目

目录 1.功能需求 2.安装插件 2.1 安装NodeJS插件 2.2 安装SVN插件 3.配置环境 3.1 NodeJS环境 4.新建任务配置部署信息 4.1 源代码管理 4.2 构建触发器 4.3 构建环境 4.4 构建步骤 5.构建项目 5.1 点击查看控制台日志 1.功能需求 使用Jenkins从SVN上拉取Vue项…

C#基础学习--异步编程

什么是异步 启动程序时&#xff0c;系统会在内存中创建一个新的进程。进程是构成运行程序的资源的集合。进程是构成运行程序的资源的集合。这些资源包括虚地址空间&#xff0c;文件句柄和许多其他程序运行所需的东西 在进程内部&#xff0c;系统创建了一个称为线程的内核&…

思科实验 EIGRP

1.1.1 实验目的 通过对 CCNA 课程中的 EIGRP 实验部分进行回顾&#xff0c;从而更加准确掌握 EIGRP 路由协议的 配置方法&#xff0c;以及对 network 命令的正确理解。并且学会对 EIGRP 路由协议查看排错的相关命 令。 1.1.2 实验拓扑 拓扑说明&#xff1a;本实验由两台思科路…

ai文案生成器免费-ai文案改写软件免费

让你的文章更加精彩- AI文章润色 在今天的信息化时代&#xff0c;文章编辑变得越来越容易。但是&#xff0c;如何让自己的文章在海量信息中脱颖而出并吸引更多的阅读者却是一项挑战。 如果你是一位写作爱好者或你是一位工作中需要写作的从业者&#xff0c;你会发现你需要让你…

蓝桥杯15单片机--串口通信模块

目录 一、计算机常用通信方式 二、串口通信UART 三、串口通信寄存器 &#xff08;1&#xff09;串行口1控制寄存器SCON和PCON ​&#xff08;2&#xff09;串行口1数据缓冲器SBUF &#xff08;3&#xff09;串行口1辅助寄存器AUXR &#xff08;4&#xff09;串行口1中断…

蛇优化算法

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 蛇优化算法算法流程图初始化进化操作搜索阶段&#xff08;无食物&#xff09;——全局搜索搜索阶段&#xff08;有食物&#xff09;——局部搜索战斗模式交配模式 备…