题解:本题主要考查模拟,队列,因为顺序已经摆好了,所以关键在于节水结束时的替换,将下个的量赋给已结束的,就可以啦。
代码如下:
#include <iostream>
using namespace std;
int s[11000],num,t,n,m;
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++) cin>>s[i];
t=m+1;
while(t<=n+m)
{
for(int i=1;i<=m;i++)
{
s[i]--;
if(s[i]==0)
{
s[i]=s[t];
t++;
}
}
num++;
}
cout<<num;
return 0;
}