codeVS1138 聪明的质监员

二分水题。为什么要写这道题呢,因为要辨明long long的读入与输出。

经过俩天的调试(我还以为我代码写错了)。。。

发现codeVS,tyvj输入输出用lld,vijos用I64d

这篇题解除了我应该也不会有人看见。。所以肯定还会有大量人入坑。

呜呼哀哉。

#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<iostream>
using namespace std;
const int maxn = 200000 + 10;
const int maxw = 2000000;

int n,m;
long long s[maxn],t[maxn];
int w[maxn],v[maxn];
int L[maxn],R[maxn];
int l,r,mid;
long long res,res2,S1;

long long solve() {
    t[0]=0; s[0]=0; res=0LL;
    for(int i=1;i<=n;i++)
        if(w[i]>=mid) {
            t[i]=t[i-1]+1;
            s[i]=(long long)s[i-1]+v[i];
        }
        else {
            t[i]=t[i-1];
            s[i]=s[i-1];
        }
    for(int i=1;i<=m;i++)
        res += (t[R[i]]-t[L[i]-1])*(s[R[i]]-s[L[i]-1]);
    return res;
}

int main() {
    scanf("%d%d%lld",&n,&m,&S1);
    l=0;r=maxw;
    for(int i=1;i<=n;i++) {
        scanf("%d%d",&w[i],&v[i]);
        r=max(r,w[i]);
    }
    for(int i=1;i<=m;i++) scanf("%d%d",&L[i],&R[i]);
    r++;
    res2=10000000000000000LL;
    while(l<r) {
        mid=(l+r)>>1;
        long long res = solve();
        res2=min(res2,abs(res-S1));
        if(res>S1) l=mid+1;
        else r=mid;
    }
    for(int i=l;i<=r;i++) solve();
    cout<<res2<<‘\n‘;
    return 0;
}

时间: 2024-12-29 11:24:42

codeVS1138 聪明的质监员的相关文章

NOIP2011聪明的质监员题解

631. [NOIP2011] 聪明的质监员 ★★   输入文件:qc.in   输出文件:qc.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n个矿石,从 1 到n逐一编号,每个矿石都有自己的重量wi以及价值vi.检验矿产的流程是: 1. 给定 m个区间[Li,Ri]: 2. 选出一个参数W: 3. 对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi: Yi=∑j1×∑jvj, j∈[

vijos1740 聪明的质监员 (二分、区间求和)

http://www.rqnoj.cn/problem/657 https://www.vijos.org/p/1740 P1740聪明的质检员 请登录后递交 标签:NOIP提高组2011[显示标签] 描述 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n个矿石,从1到n逐一编号,每个矿石都有自己的重量wi以及价值vi.检验矿产的流程是: 1.给定m个区间[Li,Ri]: 2.选出一个参数W: 3.对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi: Yi = ∑1

P1314 聪明的质监员

P1314 聪明的质监员 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[Li,Ri]: 2 .选出一个参数 W: 3 .对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi: 这批矿产的检验结果Y 为各个区间的检验值之和.即:Y1+Y2...+Ym 若这批矿产的检验结果与所给标准值S 相差太多,就需要再去检验另一批矿产.小T 不想费时间去

noip2011 聪明的质监员

P1314 聪明的质监员 322通过 1.5K提交 题目提供者该用户不存在 标签二分2011NOIp提高组 难度提高+/省选- 提交该题 讨论 题解 记录 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[Li,Ri]: 2 .选出一个参数 W: 3 .对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi: 这批矿产的检验结果Y 为各个区间的

NOIP2011提高组 聪明的质监员 -SilverN

题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[Li,Ri]: 2 .选出一个参数 W: 3 .对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi: 这批矿产的检验结果Y 为各个区间的检验值之和.即:Y1+Y2...+Ym 若这批矿产的检验结果与所给标准值S 相差太多,就需要再去检验另一批矿产.小T 不想费时间去检验另一批矿产,所以他想通

[Codevs] 1138 聪明的质监员

1138 聪明的质监员 2011年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n 个矿石,从1到n 逐一编号,每个矿石都有自己的重量wi 以及价值vi.检验矿产的流程是:见图 若这批矿产的检验结果与所给标准值S 相差太多,就需要再去检验另一批矿产.小T不想费时间去检验另一批矿产,所以他想通过调整参数W 的值,让检验结果尽可能的靠近标准值

luogu P1314 聪明的质监员 x

P1314 聪明的质监员(至于为什么选择这个题目,可能是我觉得比较好玩呗) 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[Li,Ri]: 2 .选出一个参数 W: 3 .对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi: 这批矿产的检验结果Y 为各个区间的检验值之和.即:Y1+Y2...+Ym 若这批矿产的检验结果与所给标准值S 相差

2011 聪明的质监员

聪明的质监员 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[Li,Ri]: 2 .选出一个参数 W: 3 .对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi: 这批矿产的检验结果Y 为各个区间的检验值之和.即:Y1+Y2...+Ym 若这批矿产的检验结果与所给标准值S 相差太多,就需要再去检验另一批矿产.小T 不想费时间去检验另一批矿

P1314 聪明的质监员[二分答案]

题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 nn 个矿石,从 11到nn 逐一编号,每个矿石都有自己的重量 w_i*w**i* 以及价值v_i*v**i* .检验矿产的流程是: 1 .给定mm个区间[L_i,R_i][Li,Ri]: 2 .选出一个参数WW: 3 .对于一个区间[L_i,R_i][Li,Ri],计算矿石在这个区间上的检验值Y_i*Y**i*: 这批矿产的检验结果YY 为各个区间的检验值之和.即:Y_1+Y_2...+Y_mY1+Y2...+*Y**