anon的私货
大意:
要求除全 0 连续子数组外的每个连续子数组的平均数都大于等于 1,0最多有多少个
分析:
证明太菜了,不会,贪心的策略大概就是左右两边加起来0的个数不超过x-1,能放左边尽量放左边
#include<bits/stdc++.h>
using namespace std;
using i64 = long long;
#define ios ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
int n;
int a[100050];
i64 ans=0;
int main(){
ios;
cin>>n;
for(int i = 1;i<=n;++i) cin>>a[i];
a[0]=a[n+1]=0x3f3f3f3f;
for(int i = 0;i<=n;++i){
int x = min(a[i]-1,a[i+1]-1);
a[i]-=x;
a[i+1]-=x;
ans+=x;
}
cout<<ans;
return 0;
}
优化算法问题:最大全0子数组限制下的连续子数组平均值
文章讨论了一个编程问题,要求在满足除全0连续子数组外的每个连续子数组平均数大于等于1的前提下,最大化0的个数。作者提出了一个贪心策略并用C++代码实现,展示了如何通过调整数组来达到最优解。
1355

被折叠的 条评论
为什么被折叠?



