【二分】【P1314】 【NOIP2011D2T2】聪明的质监员
Description
小T 是一名质量监督员,最近负责检验一批矿产的质量。这批矿产共有 \(n\) 个矿石,从 \(1\) 到 \(n\) 逐一编号,每个矿石都有自己的重量 \(w_i\) 以及价值 \(v_i\) 。检验矿产的流程是:
1 、给定 \(m\) 个区间 \([L_i,R_i]\) ;
2 、选出一个参数 $ W$ ;
3 、对于一个区间 \([L_i,R_i]\) ,计算矿石在这个区间上的检验值 \(Y_i\) :
\(Y_i=\sum_{j}1 \times \sum_{j}v_{j}\),其中\(j~\in~ [L_i,R_i]\)且\(w_j>W\),\(j\)是矿石编号。
这批矿产的检验结果 \(Y\) 为各个区间的检验值之和。即: \(Y_1+Y_2...+Y_m\)
若这批矿产的检验结果与所给标准值 \(S\) 相差太多,就需要再去检验另一批矿产。小T不想费时间去检验另一批矿产,所以他想通过调整参数W 的值,让检验结果尽可能的靠近标准值 \(S\) ,即使得 \(S-Y\) 的绝对值最小。请你帮忙求出这个最小值。
Input
第一行包含三个整数 \(n,m,S\) ,分别表示矿石的个数、区间的个数和标准值。
接下来的 \(n\) 行,每行 \(2\) 个整数,中间用空格隔开,第 \(i+1\) 行表示 \(i\) 号矿石的重量 \(w_i\) 和价值 \(v_i\) 。
接下来的 \(m\) 行,表示区间,每行 \(2\) 个整数,中间用空格隔开,第 \(i+n+1\) 行表示区间 \([L_i,R_i]\) 的两个端点 \(L_i\) 和 \(R_i\) 。注意:不同区间可能重合或相互重叠。
Output
一个整数,表示所求的最小值。
Sample Input
5 3 15
1 5
2 5
3 5
4 5
5 5
1 5
2 4
3 3
Sample Output
10
Hint
对于\(100\%\)的数据,有$ 1 ≤n ,m≤200,000,0 < w_i,v_i≤10^6,0 < S≤10^12,1 ≤L_i ≤R_i ≤n$ 。
Solution
先来化简一下这个毒瘤表达式什么意思:
\(Y_i=\sum_{j}1 \times \sum_{j}v_{j}\),其中\(j~\in~ [L_i,R_i]\)且\(w_j>W\)。
对于乘号前面,有几个\(j\)就会增加几个\(1\),所以 \(\sum_{j}1\) 事实上就等于\(j\)。乘号后面显然是合法的\(v\)的和。
所以这个表达式的含义就是满足\(j~\in~ [L_i,R_i]\)且\(w_j>W\)的矿石数量乘上他们的权值和。
当时出题的真是闲的整这么个毒瘤表达式
那么题意就很清楚了。显然可以发现的一点是在参数\(W\)增加的时候求出来的\(Y\)是单调不减的。根据这个性质,我们可以二分W的值。
接着考虑二分的check怎么写。暴力计算整个结构显然最坏会达到\(O(n^2)\),不可做。一开始想着预处理线段树,发现貌似不可做。考虑前缀和。这样花费\(O(n)\)预处理,\(O(1)\)查询每个区间。
整个算法复杂度\(O(nlogn)\),可以通过本题。
Code
#include<cstdio>
#define rg register
#define ci const int
#define cl const long long int
typedef long long int ll;
namespace IO {
char buf[50];
}
template<typename T>
inline void qr(T &x) {
char ch=getchar(),lst=' ';
while(ch>'9'||ch<'0') lst=ch,ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
if (lst=='-') x=-x;
}
template<typename T>
inline void write(T x,const char aft,const bool pt) {
if(x<0) {putchar('-');x=-x;}
int top=0;
do {
IO::buf[++top]=x%10+'0';
x/=10;
} while(x);
while(top) putchar(IO::buf[top--]);
if(pt) putchar(aft);
}
template <typename T>
inline T mmax(const T &a,const T &b) {if(a>b) return a;return b;}
template <typename T>
inline T mmin(const T &a,const T &b) {if(a<b) return a;return b;}
template <typename T>
inline T mabs(const T &a) {if(a<0) return -a;return a;}
template <typename T>
inline void mswap(T &a,T &b) {T temp=a;a=b;b=temp;}
const ll maxn = 200010;
const ll INF = 1ll<<60;
struct M {
ll w,v;
};
M MU[maxn];
struct R {
ll l,r;
};
R RU[maxn];
ll n,m,s,ans=INF;
ll sum[maxn],cnt[maxn];
int main() {
qr(n);qr(m);qr(s);
for(rg int i=1;i<=n;++i) {qr(MU[i].w);qr(MU[i].v);}
for(rg int i=1;i<=m;++i) {qr(RU[i].l);qr(RU[i].r);}
rg ll l=0,r=1e6,mid;
while(l<=r) {
ll _ans=0;
mid=(l+r)>>1;
for(rg int i=1;i<=n;++i) {
sum[i]=sum[i-1];cnt[i]=cnt[i-1];
if(MU[i].w>mid) sum[i]+=MU[i].v,++cnt[i];
}
for(rg int i=1;i<=m;++i) {
_ans+=(sum[RU[i].r]-sum[RU[i].l-1])*(cnt[RU[i].r]-cnt[RU[i].l-1]);
}
ans=mmin(ans,mabs(_ans-s));
if(_ans<s) r=mid-1;else l=mid+1;
}
write(ans,'\n',true);
}
【二分】【P1314】 【NOIP2011D2T2】聪明的质监员的更多相关文章
- 【洛谷p1314】聪明的质监员
聪明的质监员[题目链接] 有关算法: 二分答案: 但是你只二分答案是不够的,因为你check会炸,所以还要考虑前缀和: 首先假装我们的check已经写好了,main函数: int main() { n ...
- 洛谷 P1314 【聪明的质监员】
二分 思路: 这道题思路还是蛮好想的,一开始想的是暴力枚举w,然后再仔细一看,w增长时,y肯定减小,那么思路出来了: 二分 但是在时二分时,分得是左右端点lr,做错了 求出w的上下界,然后二分 只二分 ...
- P1314 聪明的质监员(前缀和+二分)
P1314 聪明的质监员 显然可以二分参数W 统计Y用下前缀和即可. #include<iostream> #include<cstdio> #include<cstri ...
- Luogu P1314 聪明的质监员(二分+前缀和)
P1314 聪明的质监员 题意 题目描述 小\(T\)是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有\(n\)个矿石,从\(1\)到\(n\)逐一编号,每个矿石都有自己的重量\(w_i\) ...
- 【洛谷P1314】[NOIP2011]聪明的质监员
聪明的质监员 题目链接:https://www.luogu.org/problemnew/show/P1314 Y(W)随W的值增大而减小 二分W的值,找到最小的W使得Y(W)>S: 比较Y(W ...
- 洛谷P1314 聪明的质监员
P1314 聪明的质监员 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: ...
- luogu P1314 聪明的质监员 x
P1314 聪明的质监员(至于为什么选择这个题目,可能是我觉得比较好玩呗) 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自 ...
- 洛谷P1314 [NOIP2011提高组Day2T2] 聪明的质监员
P1314 聪明的质监员 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: ...
- Luogu P1314 [NOIP2011 提高组] 聪明的质监员
P1314 [NOIP2011 提高组] 聪明的质监员 题意 题目描述 给定\(n\)个物品,给定每个物品的 重量 \(w_i\) 和 价值 \(v_i\) 给定一个标准值 \(s\) 以及一个参数 ...
- AC日记——聪明的质监员 洛谷 P1314
聪明的质监员 思路: 二分: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 200005 #define l ...
随机推荐
- Fiddler使用总结(三)
我们知道Fiddler是位于客户端和服务器之间的代理,它能够记录客户端和服务器之间的所有 HTTP请求,可以针对特定的HTTP请求,分析请求数据.设置断点.调试web应用.修改请求的数据,甚至可以修改 ...
- <cfenv>(fenv.h) _c++11
头文件 <cfenv>(fenv.h) c++11 浮点环境 这个头文件声明了一系列的函数和宏去访问浮点环境,以及特殊的类型. 浮点环境维护一系列的状态标志(status flags)和具 ...
- Linux中常用Shell命令
本随笔文章,由个人博客(鸟不拉屎)转移至博客园 写于:2018 年 05 月 04 日 原地址:https://niaobulashi.com/archives/linux-shell.html -- ...
- ThreadLocal 线程的私有内存
话说在<操作系统原理>这门课里面,我们学到了很多概念:进程.线程.锁.PV操作.读写者问题等等,大家还记得么?(估计有些概念早已忘记了吧,哈哈哈~) 其中关于进程.线程和锁的东西是我们平时 ...
- POJ 3498 March of the Penguins(网络最大流)
Description Somewhere near the south pole, a number of penguins are standing on a number of ice floe ...
- C++ 学习笔记之 引用
一.定义: 引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样. 二.用法: 基本用法 例如: int & a = b; 引用作为函数返回值 先看一个例子: #inclu ...
- PokeCats开发者日志(十四)——终章
已经不知道离PokeCats游戏开始开发有多少个晚上了,今晚心血来潮整理随笔的时候发现这个故事还没有划上句号. 故事的结局是最终我拿到了软著权,但是没办法上架到任何一个知名的安卓app市场,连 ...
- 语音信号处理之动态时间规整(DTW)(转)
这学期有<语音信号处理>这门课,快考试了,所以也要了解了解相关的知识点.呵呵,平时没怎么听课,现在只能抱佛脚了.顺便也总结总结,好让自己的知识架构清晰点,也和大家分享下.下面总结的是第一个 ...
- js设计模式之代理模式以及订阅发布模式
为啥将两种模式放在一起呢?因为这样文章比较长啊. 写博客的目的我觉得首要目的是整理自己的知识点,进而优化个人所得知识体系.知识成为个人的知识,就在于能够用自己的话表达同一种意义. 本文是设计模式系列文 ...
- Swoole和Swoft的那些事 (Http/Rpc服务篇)
https://www.jianshu.com/p/4c0f625d5e11 Swoft在PHPer圈中是一个门槛较高的Web框架,不仅仅由于框架本身带来了很多新概念和前沿的设计,还在于Swoft是一 ...