关于题解没有解释样例,也没解释样例看着很懵这回事 传送门 :
题意问题转为 : 给你一个数组 a [ ] a[] a[],你可以选出任意数, 他们的和不超过 t t t
显然,你选出的数会将数组分成若干段 ,求最大的长度最小
样例解释
17 11 17\ \ 11 17 11 645 { 2 } 5 { 3 } 452 { 3 } 452 { 3 } 635 645\ \{2\}\ 5\ \{3\}\ 452\ \{3\}\ 4 52\ \{3\}\ 635 645 {2} 5 {3} 452 {3} 452 {3} 635
即得样例
思路因为 问题字眼中存在 最大长度最小,我们考虑使用二分
首先 我们假设已经知道 最大长度 考虑 最小花费代价
显然和 1089.烽火传递,在连续长度为 m m m 至少要选一个点
因此我么们可以考虑 二分答案即 二 分 最 大 长 度 二分最大长度 二分最大长度
显然的,如果长度不满足我们需要扩大,否则缩小 ( 一眼二分性质)
因此 动态规划的状态表示没变
状态表示 f [ i ] f[i] f[i]以 i i i结尾的区间
状态计算 f [ i ] = f [ j ] m i n + w [ i ] f[i]=f[j]_{min}+w[i] f[i]=f[j]min+w[i]
Mycodeconst int N = 5e4+10;
int a[N],n,m;
int q[N];
bool check(int x){
int dp[N] = {0};
int hh = 0 , tt = 0 ;
for(int i=1;i>m;
for(int i=1;i>a[i];
int l =0 , r= n;
while(l>1;
if(check(mid)) r = mid-1;
else l = mid+1;
}
cout
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?