当前位置: 首页 > news >正文

网络建站东北企业网络规划设计与实现

网络建站东北,企业网络规划设计与实现,昆明网络公司开发,做网站要考虑的问题hard:https://leetcode.cn/problems/split-array-largest-sum/ 给定一个非负整数数组 nums 和一个整数 m ,你需要将这个数组分成 m 个非空的连续子数组。 设计一个算法使得这 m 个子数组各自和的最大值最小。 示例 1:输入:nums [7,2,5,1…
  • hard:https://leetcode.cn/problems/split-array-largest-sum/

  • 给定一个非负整数数组 nums 和一个整数 m ,你需要将这个数组分成 m 个非空的连续子数组

  • 设计一个算法使得这 m 个子数组各自和最大值最小

示例 1:输入:nums = [7,2,5,10,8], m = 2
输出:18
解释:
一共有四种方法将 nums 分割为 2 个子数组。 
其中最好的方式是将其分为 [7,2,5][10,8] 。
因为此时这两个子数组各自的和的最大值为18,在所有情况中最小。
示例 2:输入:nums = [1,2,3,4,5], m = 2
输出:9
示例 3:输入:nums = [1,4,4], m = 3
输出:4提示:1 <= nums.length <= 1000
0 <= nums[i] <= 106
1 <= m <= min(50, nums.length)

题解

  • 令 dp[i][j]表示将数组的前 i 个数分割为 j 组所能得到的最大连续子数组和的最小值

  • 确定装填转移方程(考虑dp[i][j]需要遍历所有分为j-1组的情况):
    d p [ i ] [ j ] = m i n k = 0 i − 1 { m a x ( d p [ k ] [ j − 1 ] , s u b ( k + 1 , i ) ) } = m i n k = 0 i − 1 { m a x ( d p [ k ] [ j − 1 ] , s u m ( n u m s [ k + 1 … j ] ) ) } dp[i][j]= min_{k=0}^{ i−1} \{max(dp[k][j−1],sub(k+1,i))\}\\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ = min_{k=0}^{ i−1} \{max(dp[k][j−1],sum(nums[k+1…j]))\} dp[i][j]=mink=0i1{max(dp[k][j1],sub(k+1,i))}                               =mink=0i1{max(dp[k][j1],sum(nums[k+1j]))}

  • 确定边界:填表法

        nums = [7,2,5,10,8],m=2。

i\j012
0无法分为0组INT_MAXINT_MAX
1无法分为0组71个数无法分为2组(i<j)
2无法分为0组7+2 m i n ( [ 7 ] , [ 2 ] ) = 2 min([7],[2])=2 min([7],[2])=2
3无法分为0组7+2+5 m i n [ m a x ( d p [ 1 ] [ 1 ] , [ 2 , 5 ] ) m a x ( d p [ 2 ] [ 1 ] , [ 5 ] ) ] = 7 min\begin{bmatrix} max(dp[1][1],[2,5]) \\ max(dp[2][1],[5]) \end{bmatrix}=7 min[max(dp[1][1],[2,5])max(dp[2][1],[5])]=7
4无法分为0组7+2+5+10 m i n [ m a x ( d p [ 1 ] [ 1 ] , [ 2 , 5 , 10 ] ) m a x ( d p [ 2 ] [ 1 ] , [ 5 , 10 ] ) m a x ( d p [ 3 ] [ 1 ] , [ 10 ] ) ] = 14 min\begin{bmatrix} max(dp[1][1],[2,5,10]) \\ max(dp[2][1],[5,10]) \\ max(dp[3][1],[10]) \end{bmatrix}=14 min max(dp[1][1],[2,5,10])max(dp[2][1],[5,10])max(dp[3][1],[10]) =14 前*个数分为一组和剩下的部分
5无法分为0组7+2+5+10+8 m i n [ m a x ( d p [ 1 ] [ 1 ] , [ 2 , 5 , 10 , 8 ] ) m a x ( d p [ 2 ] [ 1 ] , [ 5 , 10 , 8 ] ) m a x ( d p [ 3 ] [ 1 ] , [ 10 , 8 ] ) m a x ( d p [ 4 ] [ 1 ] , [ 8 ] ) ] = 18 min\begin{bmatrix} max(dp[1][1],[2,5,10,8]) \\ max(dp[2][1],[5,10,8]) \\ max(dp[3][1],[10,8])\\ max(dp[4][1],[8]) \end{bmatrix}=18 min max(dp[1][1],[2,5,10,8])max(dp[2][1],[5,10,8])max(dp[3][1],[10,8])max(dp[4][1],[8]) =18

code

class Solution {
public:int splitArray(vector<int>& nums, int m) {int n = nums.size();vector<vector<long long>> dp(n + 1, vector<long long>(m + 1, LLONG_MAX));vector<long long> sub(n + 1, 0);for (int i = 0; i < n; i++) {sub[i + 1] = sub[i] + nums[i];}dp[0][0] = 0;for (int i = 1; i <= n; i++) {for (int j = 1; j <= min(i, m); j++) {for (int k = 0; k < i; k++) {dp[i][j] = min(dp[i][j], max(dp[k][j - 1], sub[i] - sub[k]));}}}return (int)dp[n][m];}
};
http://www.yayakq.cn/news/496834/

相关文章:

  • esp8266做网站天津网站建站推广
  • 营业执照办好了就可以做网站了吗ccyy切换路线专线
  • 上海家居网站建设双流兴城投资建设有限公司网站
  • 企业宣传文案网站界面优化
  • 酒店做网站深圳画册设计排版
  • 成都企业网站排名优化wordpress 导入主题
  • 上海人才网官网招聘招聘郑州seo顾问热狗
  • 网站建设报价比较表wordpress 群聊汉化版插件
  • html5制作手机网站教程手袋 东莞网站建设
  • 建行个人余额查询系统官网做网站优化常用工具
  • mvc 网站模板重庆官网seo分析
  • 湘潭市网站建设科技有限公司网络工程建设流程
  • 塘下做网站外贸 推广网站
  • 电子商务网站设计说明书如何做网站充值接口
  • 宁波企业做网站网站建设公司重庆
  • 做网站开发用笔记本要什么配置电子商务网站建设与实践
  • 济南科技网站建设计算机程序设计网站开发
  • 家用电脑进行网站建设网站轮播图
  • 上国外网站速度慢网业进不去什么原因
  • 网站备案的核验单wordpress 文章系列插件
  • 网站建设技术咨询协议泉州中企网站做的好吗
  • 怎么做刷业务网站网站页面和图片设计
  • 高校网站如何建设云南网站设计哪家好
  • 什么样的网站空间做电影网站不卡建设自己的淘宝优惠券网站
  • 西苑做网站公司青岛网站制作案例
  • 迈网科技 官方网站重庆企业网站建设哪家好
  • 网站前台做好以后用什么生成后台管理系统东莞网络公司 网站建设
  • 网站设计师培训学校gpl2 wordpress
  • win7 建设网站服务器西地那非最佳起效时间
  • 宁波建设工程报名网站广州专业网站设计定制