题目描述

小T 是一名质量监督员,最近负责检验一批矿产的质量。这批矿产共有 n 个矿石,从 1 到 n 逐一编号,每个矿石都有自己的重量 \(w_i\)​ 以及价值 \(v_i\) 。检验矿产的流程是:

1 、给定 m 个区间 \([L_i,R_i]\) ;

2 、选出一个参数 W ;

3 、对于一个区间 \([L_i,R_i]\),计算矿石在这个区间上的检验值 \(Y_i\)​ :

这批矿产的检验结果 YYY 为各个区间的检验值之和。即: \(Y_1+Y_2...+Y_m\)

若这批矿产的检验结果与所给标准值 SSS 相差太多,就需要再去检验另一批矿产。小T不想费时间去检验另一批矿产,所以他想通过调整参数W 的值,让检验结果尽可能的靠近标准值 S ,即使得 \(S-Y\) 的绝对值最小。请你帮忙求出这个最小值。

输入输出格式

输入格式:

第一行包含三个整数 n,m,Sn,m,Sn,m,S ,分别表示矿石的个数、区间的个数和标准值。

接下来的 nnn 行,每行 222 个整数,中间用空格隔开,第 i+1i+1i+1 行表示 iii 号矿石的重量 wiw_iwi​ 和价值 viv_ivi​ 。

接下来的 mmm 行,表示区间,每行 222 个整数,中间用空格隔开,第 i+n+1i+n+1i+n+1 行表示区间 [Li,Ri][L_i,R_i][Li​,Ri​] 的两个端点 LiL_iLi​ 和 RiR_iRi​ 。注意:不同区间可能重合或相互重叠。

输出格式:

一个整数,表示所求的最小值。

输入输出样例

输入样例#1: 复制

5 3 15

1 5

2 5

3 5

4 5

5 5

1 5

2 4

3 3

输出样例#1: 复制

10

【数据范围】

对于 \(10\%\) 的数据,有 \(1 ≤n ,m≤10\) ;

对于 \(30\%\) 的数据,有 \(1 ≤n ,m≤500\) ;

对于 \(50\%\) 的数据,有 \(1 ≤n ,m≤5,000\) ;

对于 \(70\%\) 的数据,有 \(1 ≤n ,m≤10\) ;

对于 \(100\%\) 的数据,有 \(1 ≤n ,m≤200,000,0 < w_i,v_i≤10^6,0 < S≤10^{12},1 ≤L_i ≤R_i ≤n\) 。


二分答案 \(W\) 求出 \(Y\) 和 \(S\) 比较,如果 \(Y>S\) 把右端点左移至 \(mid-1\),如果 \(Y<S\) 把左端点右移至 \(mid+1\)


#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstring> using namespace std; int w[1000008],v[1000008],i,m,n,j,k,l[1000008],r[1000008],maxx;
long long d[1000008],t[1000008],ans=2147483647000000,s;
void add(int now,int k,long long *b)
{
for(int i=now;i<=n;i+=(i&(-i))) b[i]+=k;
} long long ff(int now,long long *b)
{
long long ans=0;
for(int i=now;i>0;i-=(i &(-i))) ans+=b[i];
return ans;
} long long dfs(int ww)
{
long long s=0,z=0,Y=0;
memset(d,0,sizeof(d));
memset(t,0,sizeof(t));
for(int i=1;i<=n;i++)
if(w[i]>=ww) add(i,1,d),add(i,v[i],t);
for(int i=1;i<=m;i++)
Y+=((ff(r[i],d)-ff(l[i]-1,d))*(ff(r[i],t)-ff(l[i]-1,t)));
return Y;
} void ef(int ll,int rr)
{
while(ll<=rr)
{
int mid=(ll+rr+1)/2;
long long y=dfs(mid);
ans=min(ans,abs(y-s));
if(s>y) rr=mid-1;
else ll=mid+1;
if(s==y) return;
}
} int main()
{
scanf("%d%d%lld",&n,&m,&s);
for(i=1;i<=n;i++) scanf("%d%d",&w[i],&v[i]),maxx=max(maxx,w[i]);
for(i=1;i<=m;i++) scanf("%d%d",&l[i],&r[i]);
ef(0,maxx+1);
printf("%lld",ans);
}

P1314 聪明的质监员的更多相关文章

  1. P1314 聪明的质监员(前缀和+二分)

    P1314 聪明的质监员 显然可以二分参数W 统计Y用下前缀和即可. #include<iostream> #include<cstdio> #include<cstri ...

  2. 洛谷P1314 聪明的质监员

    P1314 聪明的质监员 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: ...

  3. luogu P1314 聪明的质监员 x

    P1314 聪明的质监员(至于为什么选择这个题目,可能是我觉得比较好玩呗) 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自 ...

  4. Luogu P1314 聪明的质监员(二分+前缀和)

    P1314 聪明的质监员 题意 题目描述 小\(T\)是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有\(n\)个矿石,从\(1\)到\(n\)逐一编号,每个矿石都有自己的重量\(w_i\) ...

  5. 洛谷P1314 聪明的质监员 题解

    题目 聪明的质监员 题解 这道题和之前Sabotage G的那道题类似,都是用二分答案求解(这道题还要简单一些,不需要用数学推导二分条件,只需简单判断一下即可). 同时为了降低复杂度,肯定不能用暴力求 ...

  6. 【luogu P1314 聪明的质监员】 题解

    题目链接:https://www.luogu.org/problemnew/show/P1314 二分答案 但是计算区间贡献的时候 直接暴力会挂 前缀和加速 #include <cstdio&g ...

  7. 洛谷 P1314 聪明的质监员 —— 二分

    题目:https://www.luogu.org/problemnew/show/P1314 显然就是二分那个标准: 当然不能每个区间从头到尾算答案,所以要先算出每个位置被算了几次: 不知为何自己第一 ...

  8. [NOIP2011] 提高组 洛谷P1314 聪明的质监员

    题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[L ...

  9. Luogu P1314 聪明的质监员 二分答案

    题目链接 Solution 这个范围不是二分就是结论题就是数学题... 然后再看一会差不多就可以看出来有单调性所以就可以确定二分的解法了 二分那个$W$,用前缀和$O(n+m)$的时间来求出对答案的贡 ...

随机推荐

  1. MySql的隔离级别总结

    使用MySql也有一段时间了,但是很多MySql相关或者说是数据库相关的知识还是一知半解,最近在学hibernate这个框架时碰到挺多和数据库相关的知识盲区,所以下面根据自己对MySql系统相关知识消 ...

  2. Java 锁机制总结

    锁的种类 独享锁 VS 共享锁 独享锁:锁只能被一个线程持有(synchronized) 共享锁:锁可以被多个程序所持有(读写锁) 乐观锁 VS 悲观锁 乐观锁:每次去拿数据的时候都乐观地认为别人不会 ...

  3. oracle 多列数据相同,部分列数据不同合并不相同列数据

    出现这样一种情况: 前面列数据一致,最后remark数据不同,将remark合并成 解决办法: 最后一列:结果详情: 使用到的语句为: select a,b,c,wm_concat(d) d,wm_c ...

  4. 【SSH网上商城项目实战04】EasyUI菜单的实现

    转自:https://blog.csdn.net/eson_15/article/details/51297705 上一节我们使用EasyUI搭建了后台页面的框架,这一节我们主要使用EasyUI技术简 ...

  5. dbUtils 中的各种 Handler 什么 意思

    ArrayHandler:把结果集中的第一行数据转成对象数组. ArrayListHandler:把结果集中的每一行数据都转成一个对象数组,再存放到List中. BeanHandler:将结果集中的第 ...

  6. SSH注解方式与XML配置方式对照表

    一.Hibernate 1.一对多注解 2.单表注解 二.Struts2 Struts2注解 三.Spring 1.IOC注解 2.AOP注解

  7. SJ定理——省选前的学习2

    ——博弈论?上SG定理!什么?不行?那就SJ定理吧. 原来还有这么个玩意... bzoj1022. 大意是Nim取石子游戏中取到最后一个石子就算输,即无法取了就获胜(原版是无法取了就输). 我们试图套 ...

  8. 【HTML&CSS】基本的入门

    在公司培训一段时间不久就去流浪了一段时间,现在回来重新捧起心爱的编程,特别亲切. 自学HTML&CSS,别人说了很多,这那这那的,无论简单还是困难,不亲自去俯下身子学习,怎么都学不会HTML和 ...

  9. 03.CSS选择器-->交集并集选择器

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. 使用postMessage通信,未触发message事件

    前提: 父子页面跨域通信,使用postMessage技术 a页面为父页面,b页面为子页面 a中包含多个iframe,部分域名是相同的,目录层级不一致,地址使用变量根据触发的条件不同拼接地址 部分代码( ...