Luogu P1314 [NOIP2011 提高组] 聪明的质监员
题意
题目描述
- 给定\(n\)个物品,给定每个物品的 重量 \(w_i\) 和 价值 \(v_i\)
- 给定一个标准值 \(s\) 以及一个参数 \(w\)
- 质检员每次会抽取\(m\)个区间,每次的抽检结果为 \(y = \sum_{l_i}^{r_i} (w_i \ge w) · \sum_{l_i}^{r_i} v_i\)
- 求出 \(\min{\mid{y - s}\mid}\)
数据范围
\(1 \le n,m \le 2^5\), \(0 < w_i, v_i \le 10^6\) \(0 < s \le 10^12\), \(1 \le l_i \le r_i \le n\)
SOLUTION
当 \(y > s\) 的时候, \(y - s > 0\) 当 \(y < s\) 的时候, \(y - s < 0\) 我们想让 \(y\) 尽可能的逼近 \(s\) 对于参数\(w\),当\(w\)越大,\(y\)越小
因此本题具有单调性。 考虑二分\(w\) 使得 \(y\) 尽可能的逼近\(s\) 即可
AC_CODE_1
#include <bits/stdc++.h>
#define LL long long
using namespace std;
const int N = 2e5 + 10;
int n, m, l = INF, r = -INF;
LL s; // 不开 long long 见祖宗 | =^_^= |
int L[N], R[N];
int w[N], v[N];
LL p1[N], p2[N];
LL chk(int x) {
for(int i = 1; i <= n; i ++ ) {
p1[i] = p1[i - 1]; p2[i] = p2[i - 1];
if(w[i] >= x) {
p1[i] += v[i];
p2[i] ++;
}
}
// printf("\n%d\n", x);
LL ANS = 0;
rep(i, 1, m) {
// printf("> %d %d %lld %lld\n",L[i], R[i], (p1[R[i]] - p1[L[i] - 1]) , (p2[R[i]] - p2[L[i] - 1]));
ANS += (p1[R[i]] - p1[L[i] - 1]) * (p2[R[i]] - p2[L[i] - 1]);
}
return ANS;
}
inline void solve() {
read(n); read(m); read(s);
rep(i, 1, n) {
read(w[i]); read(v[i]);
l = min(l, w[i]); r = max(r, w[i]);
}
rep(i, 1, m) {
read(L[i]); read(R[i]);
}
l --, r ++;
LL ans = INFF;
while(l <= r) { // 由于 l = mid + 1, r = mid - 1 因此while循环里面的条件应该是 l <= r
int mid = l + r >> 1;
LL res = chk(mid);
if(res >= s) l = mid + 1; // 如果结果 y > s 我们就让 w 大一点 这样 y就会小一点更逼近 s
else r = mid - 1; //同理
ans = min(ans, abs(res - s));
// printf("> %d %lld\n", mid, res);
}
printf("%lld\n", ans);
}
signed main()
{
// freopen("in.txt", "r", stdin);
solve();
return 0;
}
AC_CODE_2
//倍增写法
#include <cstdio>
#include <iostream>
#define LL long long
const int N = 2e5 + 10;
int n, m, ans = 1; LL s;
int w[N], v[N], L[N], R[N]; LL s1[N], s2[N];
inline LL chk(int W) {
for(int i = 1; i <= n; ++ i) {
s1[i] = w[i] >= W ? s1[i - 1] + 1 : s1[i - 1];
s2[i] = w[i] >= W ? s2[i - 1] + v[i] : s2[i - 1];
}
LL res = 0;
for(int i = 1; i <= m; ++ i ) {
res += (s1[R[i]] - s1[L[i] - 1]) * (s2[R[i]] - s2[L[i] - 1]);
}
return res;
}
int main() {
scanf("%d%d%lld", &n, &m, &s);
for(int i = 1; i <= n; i ++ ) scanf("%d%d", &w[i], &v[i]);
for(int i = 1; i <= m; i ++ ) scanf("%d%d", &L[i], &R[i]);
for(int i = 17; i >= 0; -- i) {
ans += chk(ans + (1 << i)) >= s ? (1 << i) : 0;
}
printf("%lld\n", std::min(chk(ans) - s, s - chk(ans + 1)));
return 0;
}
Luogu P1314 [NOIP2011 提高组] 聪明的质监员的更多相关文章
- NOIP2011提高组 聪明的质监员 -SilverN
题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[L ...
- Noip2011提高组 聪明的质监员
题目传送门 讲真,既然质监员这么聪明,为什么要让我们帮他设计程序? 所以还是叫ZZ的质检员吧 其实,我最想说的,不是这个题,而是这个\(\Sigma\)(一见 \(\Sigma\) 就懵逼系列) 这个 ...
- NOIP2011 提高组 聪明的质监员(二分+前缀和)
看到这道题,应该都能想到用二分,那问题是怎么去判定呢? 我们考虑用前缀和(a1统计w,a2统计v),枚举每个矿石,,当前判定的值是x,如果该矿石的w>=x,a1[i]=a1[i-1]+1,a2[ ...
- 洛谷P1314 [NOIP2011提高组Day2T2] 聪明的质监员
P1314 聪明的质监员 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: ...
- Codevs 1138 聪明的质监员 2011年NOIP全国联赛提高组
1138 聪明的质监员 2011年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 小 T 是一名质量监督员, ...
- 【洛谷P1314】[NOIP2011]聪明的质监员
聪明的质监员 题目链接:https://www.luogu.org/problemnew/show/P1314 Y(W)随W的值增大而减小 二分W的值,找到最小的W使得Y(W)>S: 比较Y(W ...
- 聪明的质监员 2011年NOIP全国联赛提高组(二分+前缀和)
聪明的质监员 2011年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 小 T 是一名质量监督员, ...
- luogu P1314 聪明的质监员 x
P1314 聪明的质监员(至于为什么选择这个题目,可能是我觉得比较好玩呗) 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自 ...
- Luogu P1314 聪明的质监员(二分+前缀和)
P1314 聪明的质监员 题意 题目描述 小\(T\)是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有\(n\)个矿石,从\(1\)到\(n\)逐一编号,每个矿石都有自己的重量\(w_i\) ...
随机推荐
- DEEP DOUBLE DESCENT: WHERE BIGGER MODELS AND MORE DATA HURT
目录 概 主要内容 Effective Model Complexity(EMC) label noise data augmentation 下降方式 SGD vs Adam Adam SGD SG ...
- 1.node接口搭建--express搭建服务器
1.新建文件夹node 2.初始化 npm init 3.安装express npm install express 4.在入口文件(index.js)我的设置入口文件为(server.js)中写 / ...
- elementUI表单嵌套表格并对每行进行校验
elementUI表单嵌套表格并对每行进行校验 elementUI 表单嵌套表格并进行校验. 目录 效果展示 代码链接 关键代码 完整代码 效果展示 先看看这是不是需要的效果^_^ 如图,Elem ...
- mysql语句1-创建库和表
一.DDL数据定义语言 就是对书库内部的对象进行创建.删除.修改等操作的语言. 关键字:create drop alter 1.连接数据库 mysql -u用户名 -p -h指定主机(不指定默认是 ...
- VUE3 之 键盘事件
1. 概述 老话说的好:宁愿自己吃亏,也不让他人吃亏. 言归正传,今天我们来聊聊 VUE3 的 键盘事件. 2. 键盘事件 2.1 敲击任意键触发事件 <body> <div id= ...
- antd递归渲染左侧菜单
- 第10组-Alpha冲刺 总结
1.基本情况 组长博客链接:https://www.cnblogs.com/cpandbb/p/14007413.html 答辩总结: ·产品偏离了最开始的方向,地图和刷一刷功能做得没那么好,外卖订单 ...
- SpringBoot学习笔记一之本地环境基础搭建
原文链接: https://www.toutiao.com/i6802935050196222471/ 工程创建 Maven创建工程 搜索maven找到project的创建 创建simple proj ...
- HIVE执行引擎TEZ学习以及实际使用
概述 最近公司在使用Tez,今天写一篇关于Tez的学习和使用随笔.Tez是Apache最新的支持DAG作业的开源计算框架,它可以将多个有依赖的作业转换为一个作业从而大幅提升DAG作业的性能.Tez并不 ...
- Unity3D开发入门教程(三)——添加启动脚本
五邑隐侠,本名关健昌,12年游戏生涯. 本教程以 Unity 3D + VS Code + C# + tolua 为例. 一.启动脚本 第一篇 "搭建开发环境",在 "配 ...