CF1917C Watering an Array 题解
解题思路
观察可以发现,我们在清零后进行第一种操作,得到的序列是单调不下降的,也就是说,在清零后,我们每两次操作最多可以获得
注意事项
可能出现将
AC 代码
#include<iostream>
#include<math.h>
#include<time.h>
#include<stdio.h>
#include<algorithm>
#define ll long long
#define int ll
#define N 2005
#define M 100005
int n,k,d,a[N],v[M];
inline void work(){
scanf("%lld%lld%lld",&n,&k,&d);
for(register int i=1;i<=n;++i)
scanf("%lld",&a[i]);
for(register int i=1;i<=k;++i)
scanf("%lld",&v[i]);
int ans,cnt=0;
for(register int i=1;i<=n;++i)
if(a[i]==i) ++cnt;
ans=cnt+((d-1)>>1);
for(register int i=1;i<=std::min(std::max(k,100000ll),d-1ll);++i){
for(register int j=1;j<=v[i%k==0?k:(i%k)];++j)
++a[j];cnt=0;
for(register int j=1;j<=n;++j){
if(a[j]==j) ++cnt;
}
int now=cnt+((d-i-1)>>1);
ans=std::max(ans,now);
}printf("%lld\n",ans);
}signed main(){
int T;scanf("%lld",&T);
while(T--) work();
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下