luogu1314 聪明的质检员
题目大意
小 T 是一名质量监督员,最近负责检验一批矿产的质量。这批矿产共有 n 个矿石,从 1
到 n 逐一编号,每个矿石都有自己的重量 wi 以及价值 vi。检验矿产的流程是:
1、给定 m 个区间[Li,Ri];
2、选出一个参数 W;
3、对于一个区间[Li,Ri],计算矿石在这个区间上的检验值 Yi :
这批矿产的检验结果 Y 为各个区间的检验值之和。即:
$$\sum_j 1\times \sum_j v_j,j\in[L_i,R_i]且w_j\geq W,j时矿石编号$$
若这批矿产的检验结果与所给标准值 S 相差太多,就需要再去检验另一批矿产。小 T
不想费时间去检验另一批矿产,所以他想通过调整参数 W 的值,让检验结果尽可能的靠近
标准值 S,即使得 S-Y 的绝对值最小。请你帮忙求出这个最小值。
解题关键
要把所有满足$w_j\geq W$的$\sum_j, \sum_j v_j$,一定要记得前缀和优化!这样就可以$O(n\log n)$解决,而不是$O(n^2\log n$了。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std; #define UpdMax(x, y) x = max(x, y)
#define ll long long
const int MAX_N = 200010, MAX_Q = 200010;
const ll INF64 = 0x3f3f3f3f3f3f3f3fll;
ll W[MAX_N], V[MAX_N];
int L[MAX_N], R[MAX_N];
int N, TotQ;
ll Y, StdY; ll GetY(ll w)
{
static ll SumV[MAX_N];
static int SumCnt[MAX_N];
memset(SumV, 0, sizeof(SumV));
memset(SumCnt, 0, sizeof(SumCnt));
for (int i = 1; i <= N; i++)
{
SumV[i] = SumV[i - 1] + V[i] * (W[i] >= w);
SumCnt[i] = SumCnt[i - 1] + (W[i] >= w);
}
ll y = 0;
for (int q = 1; q <= TotQ; q++)
{
ll cnt = SumCnt[R[q]] - SumCnt[L[q] - 1], vSum = SumV[R[q]] - SumV[L[q] - 1];
y += cnt * vSum;
}
return Y = y;
} bool LeStdY(ll w)
{
return GetY(w) <= StdY;
} bool GeStdY(ll w)
{
return GetY(w) >= StdY;
} ll LowerBound(ll l, ll r, bool (*InUpperRange)(ll))
{
if (!InUpperRange(r))
return -1;
while (l < r)
{
ll mid = (l + r) / 2;
if (InUpperRange(mid))
r = mid;
else
l = mid + 1;
}
InUpperRange(l);
return l;
} ll UpperBoundSubtract1(ll l, ll r, bool (*InLowerRange)(ll))
{
if (!InLowerRange(l))
return -1;
while (l < r)
{
ll mid = (l + r + 1) / 2;
if (InLowerRange(mid))
l = mid;
else
r = mid - 1;
}
InLowerRange(l);
return l;
} int main()
{
scanf("%d%d%lld", &N, &TotQ, &StdY);
ll MaxW = 0;
for (int i = 1; i <= N; i++)
scanf("%lld%lld", W + i, V + i);
for (int i = 1; i <= N; i++)
UpdMax(MaxW, W[i]);
for (int i = 1; i <= TotQ; i++)
scanf("%d%d", L + i, R + i);
Y = INF64;
LowerBound(1, MaxW, LeStdY);
ll y1 = Y;
Y = INF64;
UpperBoundSubtract1(1, MaxW, GeStdY);
ll y2 = Y;
printf("%lld\n", min(abs(y1 - StdY), abs(y2 - StdY)));
return 0;
}
luogu1314 聪明的质检员的更多相关文章
- Luogu 1314 【NOIP2011】聪明的质检员 (二分)
Luogu 1314 [NOIP2011]聪明的质检员 (二分) Description 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n个矿石,从 1 到n逐一编号,每个矿石都有 ...
- [NOIP 2011] 聪明的质检员
聪明的质检员 描述 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n个矿石,从1到n逐一编号,每个矿石都有自己的重量wi以及价值vi.检验矿产的流程是:1.给定m个区间[Li,Ri ...
- [NOIP2011] 聪明的质检员(二分答案)
题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[L ...
- NOIP2015聪明的质检员[二分 | 预处理]
背景 NOIP2011 day2 第二题 描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿 ...
- Vijos P1740聪明的质检员
题目 描述 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n个矿石,从1到n逐一编号,每个矿石都有自己的重量wi以及价值vi.检验矿产的流程是:1.给定m个区间[Li,Ri]:2. ...
- 洛谷 [P1314] 聪明的质检员(NOIP2011 D2T2)
###一道二分答案加前缀和### 题目中已经暗示的很明显了 "尽可能靠近" " 最小值" 本题的主要坑点在于 long long 的使用 ##abs函数不支持l ...
- luogu 1314 聪明的质检员
二分答案的边界问题还是要注意 double挨着,int+1-1, 此题用到long long,所以初始化ans要足够大,前缀和优化 依然根据check答案大小左右mid,虽然有s,但是有了+1-1加持 ...
- [NOIP2011]聪明的质检员
[问题描述] 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有$n$个矿石,从 1 到$n$逐一编号,每个矿石都有自己的重量$w_i$以及价值$v_i$.检验矿产的流程是: 1. 给 ...
- vijos P1740 聪明的质检员
题目链接:传送门 题目大意:给你n个物品,每件物品有重量 W 和价值 V,给m个区间,和一个标准值.(n,m最大200000) 要求找到一个值x,使得m个所有区间的权值和与标准值的差的绝对值最小.单个 ...
随机推荐
- idea cannot download sources解决办法
当我们点击Download Sources时: 有时候idea会出现cannot download sources的情况,如下图 解决办法如下:打开idea右下角的terminal 在里面输入 mvn ...
- google查找笔记
1.可以选择MDN.WIKI等权威的网址资料
- 20Spring切面的优先级
通过使用@order注解指定切面的优先级,值越小,优先级越高代码: package com.cn.spring.aop.impl; //加减乘除的接口类 public interface Arithm ...
- 测试Mysql悲观锁
- Springboot 缓存使用
. CachingProvider . CacheManager . Cache . Entry . Expiry 1. 开启基于注解的缓存 @EnableCaching 下面列出几个核心的注解 @C ...
- 经典算法入门 列表C/C++
排序:插入排序.选择排序.冒泡排序.归并排序.快速排序.基数排序.计数排序.桶排序 查找:二分查找 树:先根.中根.后跟遍历 图:深度优先.广度优先.最小生成树.单元最短路径.全成对最短路径 动态规划 ...
- 鳥哥的 Linux 私房菜
RootKit Hunter 後端偵測軟體之架設與執行 切換解析度為 800x600 最近更新日期:2004/11/16 由前面幾個章節的說明,我們可以曉得因為主機的某些服務是有漏洞的, 黑客們可以針 ...
- [SCOI2008]奖励关 - 状压动规 - 概率与期望
Description 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物,每次你都可以选择吃或者不吃(必须在抛出下一个宝物之前做出选择,且现在决定不吃的宝 ...
- 洛谷P1186 玛丽卡
题目描述 麦克找了个新女朋友,玛丽卡对他非常恼火并伺机报复. 因为她和他们不住在同一个城市,因此她开始准备她的长途旅行. 在这个国家中每两个城市之间最多只有一条路相通,并且我们知道从一个城市到另一个城 ...
- elasticsearch 安装ik中文分词
https://blog.csdn.net/c5113620/article/details/79339541