POJ-2018 Best Cow Fences 二分

题意:找到一个连续区间,区间的长度至少大于f,现在要求这个区间的平均值最大。

题解:

二分找答案。

每次对于2分的mid值, 都把原来的区间减去mid, 然后找到一长度至少为f的区间, 他们的区间和>=0。

代码:

 1 #include<cstdio>
 2 #include<algorithm>
 3 #include<vector>
 4 #include<queue>
 5 #include<map>
 6 #include<iostream>
 7 #include<cstring>
 8 using namespace std;
 9 #define Fopen freopen("_in.txt","r",stdin); freopen("_out.txt","w",stdout);
10 #define LL long long
11 #define ULL unsigned LL
12 #define fi first
13 #define se second
14 #define pb push_back
15 #define lson l,m,rt<<1
16 #define rson m+1,r,rt<<1|1
17 #define lch(x) tr[x].son[0]
18 #define rch(x) tr[x].son[1]
19 #define max3(a,b,c) max(a,max(b,c))
20 #define min3(a,b,c) min(a,min(b,c))
21 typedef pair<int,int> pll;
22 const int inf = 0x3f3f3f3f;
23 const LL INF = 0x3f3f3f3f3f3f3f3f;
24 const LL mod =  (int)1e9+7;
25 const int N = 1e5 + 100;
26 int n, f;
27 int a[N];
28 LL suf[N];
29 bool check(int mid){
30     for(int i = 1; i <= n; ++i)
31         suf[i] = suf[i-1] + a[i] - mid;
32     LL minval = 0;
33     for(int i = f; i <= n; ++i){
34         minval = min(minval, suf[i-f]);
35         if(suf[i] - minval >= 0) return true;
36     }
37     return false;
38 }
39 int main(){
40     scanf("%d%d", &n, &f);
41     for(int i = 1; i <= n; ++i)
42         scanf("%d", &a[i]), a[i] *= 1000;
43     int l = 0, r = inf;
44     while(l <= r){
45         int m = l+r >> 1;
46         if(check(m)) l = m + 1;
47         else r = m - 1;
48     }
49     printf("%d\n", l-1);
50     return 0;
51 }
View Code

 

posted @ 2018-11-01 09:25  Schenker  阅读(151)  评论(0编辑  收藏  举报