力扣刷题第七天 分割数组的最大值

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

设计一个算法使得这 k 个子数组各自和的最大值最小。

注:

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

力扣刷题第七天 分割数组的最大值_第1张图片

代码: 
class Solution {
public:
    int splitArray(vector& nums,int m)
    {
        int n=nums.size();
        vector> f(n+1,vector(m+1,LLONG_MAX));//vector容器创建了一个二维数组f,数组的大小为(n+1)行(m+1)列,并且初始化每个元素的值为LLONG_MAX。LLONG_MAX是C++中long long类型的最大值。
        vector sub(n+1,0);
        for(int i = 0;i

你可能感兴趣的:(动态规划,leetcode,算法,数据结构)