leetcode 813 - 最大平均和的分组(动态规划)

2023-12-30 13:32

本文主要是介绍leetcode 813 - 最大平均和的分组(动态规划),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目来源:https://leetcode-cn.com/problems/largest-sum-of-averages/

我们将给定的数组 A 分成 K 个相邻的非空子数组 ,我们的分数由每个子数组内的平均值的总和构成。计算我们所能得到的最大分数是多少。

注意我们必须使用 A 数组中的每一个数进行分组,并且分数不一定需要是整数。

示例:
输入: 
A = [9,1,2,3,9]
K = 3
输出: 20
解释: 
A 的最优分组是[9], [1, 2, 3], [9]. 得到的分数是 9 + (1 + 2 + 3) / 3 + 9 = 20.
我们也可以把 A 分成[9, 1], [2], [3, 9].
这样的分组得到的分数为 5 + 2 + 6 = 13, 但不是最大值。

思路

很显然是个动态规划问题,状态比较好设,重点在找状态转移方程。

  • 定义状态:dp[i][k],表示前i个数分成k组,能获得的最大分数。
  • 状态转移方程:
    1)若k=1,只分一组,那么获得的分数就等于sum(A[:i]) / len(A[:i])
    2)若k>1,假设从某个位置j(1 <= j <i)划分,得到一组为A[j]~A[i],那么剩下k-1组就得从A[0]~A[j-1]中划分得到,每一次划分后得到的分数为dp[j][k-1] + avg(A[j]~A[i]),要获得最大分数,所以有:
    dp[i][k] = max(dp[j][k-1] + avg(A[j]~A[i]))
  • 初始化状态:
    1)k=1,则dp[i][1] = sum(A[:i])/len(A[:i]) = sum(A[:i]) / i
    2)i < k,dp[i][k] = dp[i][k-1]
    3)i = k,dp[i][k] = sum(A[:i])

代码

class Solution(object):def largestSumOfAverages(self, A, K):""":type A: List[int]:type K: int:rtype: float""""""dp[i][k] 表示前i个数分成k组能得到的最大分数, 1<=k<=K, 1<=i<=len(A)-1如果k=1,那么dp[i][k] = sum(A[:i])/i如果k>1,假设从某个位置j(1<=j<i)划分,得到一组为A[j]~A[i],那么剩下k-1组就需要在A[0]~A[j-1]中划分得到,每一次划分后分数为 avg(A[j]~A[i]) + dp[j][k-1],从中取max,即有状态转移方程:dp[i][k] = max(dp[j][k-1] + avg(A[j]~A[i]))"""n = len(A)dp = [[0] * (K+1) for i in range(n+1)]   # dp[i][k]表示前i个数分成k组能获得的最大分数for i in range(1, n+1):dp[i][1] = float(sum(A[:i])) / i for i in range(1, n+1):for k in range(2, K+1):if k > i:dp[i][k] = dp[i][k-1]elif k == i:dp[i][k] = float(sum(A[:i]))else:dp[i][k] = max([dp[j][k-1] + float(sum(A[j:i]))/(i-j) for j in range(1, i)])return dp[n][K]

时间复杂度固定了,空间复杂度可以减小,类似01背包问题那样,dp[i][k]其实和i没什么关系,把这个维度去掉,用一维dp数组来表示即可。

这篇关于leetcode 813 - 最大平均和的分组(动态规划)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/552982

相关文章

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

MyBatis-Plus使用动态表名分表查询的实现

《MyBatis-Plus使用动态表名分表查询的实现》本文主要介绍了MyBatis-Plus使用动态表名分表查询,主要是动态修改表名的几种常见场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录1. 引入依赖2. myBATis-plus配置3. TenantContext 类:租户上下文

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

基于Nacos实现SpringBoot动态定时任务调度

《基于Nacos实现SpringBoot动态定时任务调度》本文主要介绍了在SpringBoot项目中使用SpringScheduling实现定时任务,并通过Nacos动态配置Cron表达式实现任务的动... 目录背景实现动态变更定时机制配置化 cron 表达式Spring schedule 调度规则追踪定时

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S

Python动态处理文件编码的完整指南

《Python动态处理文件编码的完整指南》在Python文件处理的高级应用中,我们经常会遇到需要动态处理文件编码的场景,本文将深入探讨Python中动态处理文件编码的技术,有需要的小伙伴可以了解下... 目录引言一、理解python的文件编码体系1.1 Python的IO层次结构1.2 编码问题的常见场景二

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的stream流分组示例详解

《Java中的stream流分组示例详解》Java8StreamAPI以函数式风格处理集合数据,支持分组、统计等操作,可按单/多字段分组,使用String、Map.Entry或Java16record... 目录什么是stream流1、根据某个字段分组2、按多个字段分组(组合分组)1、方法一:使用 Stri

浅谈MySQL的容量规划

《浅谈MySQL的容量规划》进行MySQL的容量规划是确保数据库能够在当前和未来的负载下顺利运行的重要步骤,容量规划包括评估当前资源使用情况、预测未来增长、调整配置和硬件资源等,感兴趣的可以了解一下... 目录一、评估当前资源使用情况1.1 磁盘空间使用1.2 内存使用1.3 CPU使用1.4 网络带宽二、