记录编号 570128 评测结果 AAAAAAAAAAAAAA
题目名称 [POJ 2018]最好的栅栏 最终得分 100
用户昵称 Gravatarムラサメ 是否通过 通过
代码语言 C++ 运行时间 0.098 s
提交时间 2022-03-23 18:53:15 内存使用 2.12 MiB
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
int n,f;
double l=0,r=0;
double a[100005],s[100005];
bool check(double avg){
	for(int i=1;i<=n;i++){
		s[i]=s[i-1]+a[i]-avg;
	}
	double mins=0;
	for(int k=f;k<=n;k++){
		mins=min(mins,s[k-f]);
		if(s[k]>=mins){
			return true;
		}
	}
	return false;
}
int main(){
	freopen("fences.in","r",stdin);
	freopen("fences.out","w",stdout);
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>n>>f;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		r=max(r,a[i]);
	}
	while(r-l>1e-5){
		double mid=(l+r)/2;
		if(check(mid)){
			l=mid;
		}
		else{
			r=mid;
		}
	}
	cout<<int(r*1000)<<endl;
	return 0;
}