码迷,mamicode.com
首页 > 其他好文 > 详细

luogu_P1314 聪明的质监员

时间:2019-10-27 20:59:04      阅读:63      评论:0      收藏:0      [点我收藏+]

标签:二分   ret   main   max   min   hide   color   space   ref   

传送门:https://www.luogu.org/problem/P1314

本SB犯得错误:

  1. 不开longlong见祖宗......
  2. 既没有在check中更新答案,又没有最后输出判断ans(l);和ans(l+1)哪个是更优的

二分参数W,然后前缀和一下,逐个计算检验值Y。

不开longlong见祖宗

不开longlong见祖宗

不开longlong见祖宗

 

技术图片
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define R register
typedef long long ll;
using namespace std;
ll n,m,s,ql[200100],qr[200100],w[200100],v[200100],l=1e18,r=-1e18;
ll cnt[200100];
ll sum[200100];
inline ll ans(ll fl){
    ll tot=0;
    memset(sum,0,sizeof(sum));memset(cnt,0,sizeof(cnt));
    for(R int i=1;i<=n;i++){
        if(w[i]>=fl) sum[i]+=v[i],cnt[i]++;
        sum[i]+=sum[i-1];cnt[i]+=cnt[i-1];
    }
    for(R int i=1;i<=m;i++){
        tot+=1ll*(sum[qr[i]]-sum[ql[i]-1])*(cnt[qr[i]]-cnt[ql[i]-1]);
    }
    return tot;
}
int main (){
    scanf("%lld%lld%lld",&n,&m,&s);
    for(R int i=1;i<=n;i++) scanf("%lld%lld",&w[i],&v[i]),l=min(l,w[i]),r=max(r,w[i]);
    for(R int i=1;i<=m;i++)    scanf("%lld%lld",&ql[i],&qr[i]);
    while(l<r){
        int mid=(l+r+1)>>1;
        if(ans(mid)>=s) l=mid;
        else r=mid-1;
    }
    printf("%lld\n",min(abs(ans(l)-s),abs(ans(l+1)-s)));
    return 0;
}
View Code

 

luogu_P1314 聪明的质监员

标签:二分   ret   main   max   min   hide   color   space   ref   

原文地址:https://www.cnblogs.com/coclhy/p/11748670.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!