题目描述

小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);
}

最新文章

  1. ASP.NET Core管道深度剖析(1):采用管道处理HTTP请求
  2. HTML5-01 简介
  3. 编写Java应用程序。首先,定义描述学生的类——Student,包括学号(int)、 姓名(String)、年龄(int)等属性;二个方法:Student(int stuNo,String name,int age) 用于对对象的初始化,outPut()用于输出学生信息。其次,再定义一个主类—— TestClass,在主类的main方法中创建多个Student类的对象,使用这些对象来测 试Stud
  4. java多线程系类:基础篇:07线程休眠
  5. extjs4 树列表 添加子节点 刷新所有父节点数据
  6. 开始安装 ASP.NET (4.0.30319.18408)。 出现了错误: 0x8007b799 必须具有此计算机的管理员权限才能运行此工具
  7. python指定pypi的源地址 镜像地址
  8. 【LeetCode练习题】Next Permutation
  9. xhtml头文件设置
  10. 03 EditText文本编辑框
  11. 判断某个方法是否存在,解析php函数function_exists (),method_exists()与is_callable()的区别
  12. Jmeter之Non HTTP response code: java.net.SocketException/Non HTTP response message: Permission denied: connect
  13. 【转】SSH穿越跳板机:一条命令跨越跳板机直接登陆远程计算机
  14. [Jenkins]JDK版本过高导致的java.io.IOException: Remote call on xxxx failed
  15. windows下前端开发工具遇到的问题总结(yeoman bower grunt)
  16. mask-code-python
  17. Spring Data JPA @Column 注解无效 打出的语句有下划线
  18. 用 Python 破解 WIFI 密码,走到哪里都能连 WIFI
  19. 实现Hadoop的Writable接口Implementing Writable interface of Hadoop
  20. Unity中的Transform Gizmo中的Pivot和Center

热门文章

  1. jQuery事件篇---事件对象
  2. HBase—列族数据库的术语
  3. 理解B+树算法和Innodb索引
  4. MYSQL建表问题(转)
  5. 如何使DIV居中
  6. JQuery 更改属性 JQ对象循环 each 全选反选 三元运算
  7. C++笔记(1)----此运算符函数的参数太多
  8. CoolViewPager:即刻刷新,自定义边缘效果颜色,双向自动循环,内置垂直切换效果,想要的都在这里
  9. winform基础控件-例子学习
  10. Django基础之Model操作