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

怎么创建免费的网站注册域名dns

怎么创建免费的网站,注册域名dns,国外免费注册域名的网站,电脑ps软件有免费的吗题目: 给你一个整数数组 arr,请你将该数组分隔为长度 最多 为 k 的一些(连续)子数组。分隔完成后,每个子数组的中的所有值都会变为该子数组中的最大值。 返回将数组分隔变换后能够得到的元素最大和。本题所用到的测试…

题目:
给你一个整数数组 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

提示:

1 <= arr.length <= 500
0 <= arr[i] <= 109
1 <= k <= arr.length

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/partition-array-for-maximum-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

思路:

首先要看样例来寻找灵感。

在推完前两个样例的时候,应该就会发现规律。当你从前往后开始进行的时候,每到一个位置都要进行判断,是不是要以当前位置为核心开始赋值,如果是最大值要向周围进行赋值的话,是先前还是先后,分别向前多少向后多少,这些都是你要考虑的。

就以第二个例子为例,i 从0到n-1开始进行判断:
i =0的时候那肯定是1 ;、
i =1的时候,发现4是向前k个数里最大的,因此此时的最大值是4 , 整体的和就是8 ;
i = 2的时候,发现k 个数内还是4是最大值,因此整体的和就是12 ;
i = 3 的时候,发现 k 个数内最大值是5 , 因此整体的和就是20;
i = 4 的时候,发现 k 个数内最大值是7 , 但是k=4,所以最多只能向前赋值4个数,和就是29;

好的,推到这里,应该就有感觉了吧?

没有!?那我让你有点感觉~

你会发现,i 从前向后走的时候,每走到一个新的值,那以i 结尾的整体的和的最大值其实就是可以得到的,也就是说当前位置的最终答案是可以根据之前得到的结果计算得到,都说到这了还没有感觉么?

这不就是状态转移方程嘛!这不就是DP的感觉嘛!

用dp【i】 来表示以 i 作为结尾元素的整体的最大和,最后的答案就是dp【n-1】。

那状态转移方程就可以是:
dp【i】 = max(dp【i】,( j >0 ? dp[j-1] : 0) + res*(i-j+1))

j 的含义是从 i 开始向前枚举 k 个位置 , 以为之前的每个位置的整体最大和是已经算过的,也就是dp【0】到dp【i-1】都是计算过的,那 j 从 i 开始向前枚举,用arr【j】来更新 j 到 i 内的最大值res,然后将res赋值到 j 到 i 的所有数,dp【i】就取赋值之前和赋值之后的较大值。

通过这样的状态转移方程,i 从 0 遍历到 n-1 , 最终的dp【n-1】就是要返回的答案!

代码:

class Solution {
public:int maxSumAfterPartitioning(vector<int>& arr, int k) {int n = arr.size();int dp[510] = {0};for(int i = 0 ; i < n ; i++){int res = arr[i];for(int j = i ; j >= max(i-k+1 , 0) ; j--){res = max(res , arr[j]);dp[i] = max(dp[i] , (j > 0 ? dp[j-1] : 0) + res*(i-j+1));// cout << i << " " << j << " " << res <<  endl;// cout << dp[i] << endl;}}return dp[n-1];}
};
http://www.yayakq.cn/news/385543/

相关文章:

  • 网站菜单导航制作网站怎么做微信推广
  • 做网站seo优化学校网站建设的流程
  • h5响应式网站建设报价中小学门户网站建设
  • 珠宝首饰网站建设策划书建立网站的方法
  • 网站尺寸自适应广东住房和城乡建设局网站
  • 网站搭建h5是什么乐清公司网站建设
  • 怀柔网站建设优化seo东莞建设银行电话号码
  • 行业网站建设收费明细乐清seo公司
  • 建一个收费网站 怎么收费ui设计好找工作吗?
  • 想在意大利做购物网站燕郊做网站的
  • 网站建设有多少公司网页设计与网站建设在线考试
  • 建设网站答题赚钱开发一个软件需要多久
  • 怎么修改网站信息wordpress 获得用户信息
  • 太仓网站制作网站后台示演
  • 球场 技术支持 东莞网站建设南京seo排名公司
  • 深圳网站建设公司佳速互联驾校网站源码下载
  • 有哪些做淘宝素材的网站有哪些北京制作网站多少钱
  • 网站建立需要什么技术凯叔讲故事网站谁做的
  • 网站建设中目录是什么意思wordpress get var
  • 小广告广州互邦物流网络优化建站
  • p2p网站建设规划wordpress首页显示友情链接
  • 网站服务器有哪几种网站怎样设计网址大全
  • 配资网站建设优化大师有必要安装吗
  • 福州做网站的公司有哪些海淀商城网站建设
  • 网站建设网址导航网电子商务网站怎么备案
  • 企业门户网站内容建设手机微信网站
  • 网站文章多久收录汕头市澄海区建设局网站
  • 大二学生做网站难吗百度账号注册平台
  • 网站建设系统平台wordpress如何访问后台页面
  • 乐清做网站建设公司哪家好小程序免费制作平台登录