Luogu 1314 【NOIP2011】聪明的质检员 (二分)
Luogu 1314 【NOIP2011】聪明的质检员 (二分)
Description
小 T 是一名质量监督员,最近负责检验一批矿产的质量。这批矿产共有n个矿石,从 1 到n逐一编号,每个矿石都有自己的重量wi以及价值vi。检验矿产的流程是:
- 给定 m个区间[Li,Ri];
- 选出一个参数W;
- 对于一个区间[Li,Ri],计算矿石在这个区间上的检验值Yi:
\]
这批矿产的检验结果Y为各个区间的检验值之和。即:
\]
若这批矿产的检验结果与所给标准值 S相差太多,就需要再去检验另一批矿产。小 T 不想费时间去检验另一批矿产,所以他想通过调整参数W的值,让检验结果尽可能的靠近标准值 S,即使得S−Y的绝对值最小。请你帮忙求出这个最小值。
Input
第一行包含三个整数n,m,S,分别表示矿石的个数、区间的个数和标准值。
接下来的n 行,每行2 个整数,中间用空格隔开,第i+1 行表示i 号矿石的重量wi 和价值vi 。
接下来的m 行,表示区间,每行2 个整数,中间用空格隔开,第i+n+1 行表示区间[Li,Ri]的两个端点Li 和Ri。注意:不同区间可能重合或相互重叠。
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
Http
Luogu:https://www.luogu.org/problem/show?pid=1314
Source
二分
题目大意
给出n组二元组和m个区间,现在定义一个区间上的检验结果为这个区间上所有二元组中,第一个数大于W的二元组的第二个数*这些二元组的个数。定义整个的检验结果为给定的m个区间的检验结果之和。将整个的检验结果与一给定的标准值相比,两者之差的绝对值即为这个W对应的答案。现在求W让这个答案最小,求出最小值。
解决思路
讲题目的思路理清后,我们可以想到二分W的值。因为这个整个的检验结果与W是保持单调的,若W增大,则检验结果变小,反之变大。
所以我们可以二分W,每次二分出W后,计算一下其检验结果,若检验结果大于给定的S,则将左端点右移,否则将右端点左移。注意,最后输出的答案是每一次的检验结果与S作差的绝对值的最小值。
至于计算检验结果,因为题中给定的都是区间,所以我们可以每找出一个W后\(O(n)\)计算一下前缀和,然后\(O(1)\)地计算区间和。
注意,所有的变量都要开long long。
代码
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
const int maxN=300000;
const int inf=2147483647;
ll n,m,S;
ll Ans=1e13;
ll Weight[maxN];
ll Value[maxN];
ll Rangel[maxN];
ll Ranger[maxN];
ll Sum[maxN];
ll Cnt[maxN];
ll read();
bool Solve(ll nowW);
int main()
{
	n=read();
	m=read();
	S=read();
	ll l=0,r=0;
	for (int i=1;i<=n;i++)
	{
		Weight[i]=read();
		Value[i]=read();
		r=max(r,Weight[i]);//r取最大值
	}
	for (int i=1;i<=m;i++)
	{
		Rangel[i]=read();
		Ranger[i]=read();
	}
	r=r+100;//为了防止出错,扩大上限
	while (l<=r)//二分W
	{
		ll mid=(l+r)>>1;
		if (Solve(mid))
			l=mid+1;
		else
			r=mid-1;
		//cout<<l<<" "<<r<<endl;
	}
	cout<<Ans<<endl;
	return 0;
}
ll read()
{
	ll x=0;
	char ch=getchar();
	while ((ch<'0')||(ch>'9'))
		ch=getchar();
	while ((ch>='0')&&(ch<='9'))
	{
		x=x*10+ch-48;
		ch=getchar();
	}
	return x;
}
bool Solve(ll nowW)
{
	Sum[0]=0;
	Cnt[0]=0;
	for (int i=1;i<=n;i++)//计算前缀和,Sum是价值之和,Cnt是人数之和
	{
		Sum[i]=Sum[i-1]+((Weight[i]>=nowW)?(Value[i]):0);
		Cnt[i]=Cnt[i-1]+((Weight[i]>=nowW)?1:0);
	}
	ll tot=0;
	for (int i=1;i<=m;i++)//计算区间贡献之和
		tot+=(Sum[Ranger[i]]-Sum[Rangel[i]-1])*(Cnt[Ranger[i]]-Cnt[Rangel[i]-1]);
	Ans=min(Ans,abs(tot-S));//取最优值
	if (tot>=S)
		return 1;
	return 0;
}
Luogu 1314 【NOIP2011】聪明的质检员 (二分)的更多相关文章
- Luogu 1314 [NOIP2011] 聪明的质监员
		二分答案 + 前缀和. 题面中式子的意思是每一个区间$[l, r]$的贡献是这个区间内$w_i \geq W$的个数乘以这些$i$的$v_i$和. 很快发现了答案具有单调性,可以做两遍二分,分别看看小 ... 
- [NOIP2011] 聪明的质检员(二分答案)
		题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿产的流程是: 1 .给定m 个区间[L ... 
- NOIP2015聪明的质检员[二分 | 预处理]
		背景 NOIP2011 day2 第二题 描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 n 个矿石,从 1到n 逐一编号,每个矿石都有自己的重量 wi 以及价值vi .检验矿 ... 
- [NOIP2011] 聪明的质监员 二分+前缀和
		考试的时候打的二分但没有用前缀和维护.但是有个小细节手误打错了结果挂掉了. 绝对值的话可能会想到三分,但是注意到w增大的时候y是减小的,所以单调性很明显,用二分就可以.但注意一个问题,就是二分最后的结 ... 
- [NOIP2011]聪明的质检员
		[问题描述] 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有$n$个矿石,从 1 到$n$逐一编号,每个矿石都有自己的重量$w_i$以及价值$v_i$.检验矿产的流程是: 1. 给 ... 
- [NOIP 2011] 聪明的质检员
		聪明的质检员 描述 小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n个矿石,从1到n逐一编号,每个矿石都有自己的重量wi以及价值vi.检验矿产的流程是:1.给定m个区间[Li,Ri ... 
- NOIP2011聪明的质监员题解
		631. [NOIP2011] 聪明的质监员 ★★ 输入文件:qc.in 输出文件:qc.out 简单对比时间限制:1 s 内存限制:128 MB [问题描述] 小 T 是一名质量监督 ... 
- NC16597 [NOIP2011]聪明的质监员
		NC16597 [NOIP2011]聪明的质监员 题目 题目描述 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 \(n\) 个矿石,从 \(1\) 到 \(n\) 逐一编号,每个矿 ... 
- Luogu P1314 聪明的质监员(二分+前缀和)
		P1314 聪明的质监员 题意 题目描述 小\(T\)是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有\(n\)个矿石,从\(1\)到\(n\)逐一编号,每个矿石都有自己的重量\(w_i\) ... 
随机推荐
- SQL调优日记--并行等待的原理和问题排查
			概述 今天处理项目,客户反应数据库在某个时间段,反应特别慢.需要我们提供一些优化建议. 现象 由于是特定的时间段慢,排查起来就比较方便.直接查看这个时间段数据库的等待情况.查看等待类型发现了大量的CX ... 
- TiDB入门(四):从入门到“跑路”
			前言 前面三章基本把 TiDB 的环境弄好了,也做了一下简单测试,有兴趣的同学可以看一下: TiDB 入门(一):TiDB 简介 TiDB 入门(二):虚拟机搭建 TiDB-Ansible 部署方案 ... 
- Ionic 1 & 2 开发常见问题 Q&A
			原文发表于我的技术博客 本文分享了在 Ionic 1 & 2 版本开发过程中常见问题的一些 Q&A,供慕课网同学或其他朋友参考. 原文发表于我的技术博客 1. 版本的问题 Ionic ... 
- 20min 快速着手Markdown
			目录 Markdown介绍和基本使用 初步介绍 markdown的使用场景 为什么是 Markdown markdown的基本语法和使用平台 Q&A: Markdown介绍和基本使用 初步介绍 ... 
- yum源使用的几个报错小总结  (例如: python2.6.6 下yum不能使用: No module named yum)
			服务器上的yum突然不好使用,使用yum时有如下几个保持,解决方案如下: 1)Error: Cannot retrieve repository metadata (repomd.xml) for r ... 
- 个人博客week2
			1. 是否需要有代码规范 对于是否需要有代码规范,请考虑下列论点并反驳/支持: 这些规范都是官僚制度下产生的浪费大家的编程时间.影响人们开发效率, 浪费时间的东西. 我是个艺术家,手艺人,我有自己的规 ... 
- 《Linux内核分析》chapter4
- 微信开发-charles抓包
			在微信开发过程中有一块不能使用开发者工具进行调试,需要查看请求的返回,故使用了charles抓包工具. 环境配置 1.http://www.charlesproxy.com/getssl/ 下载cha ... 
- 程序设计第三次作业---C++计算器雏形
			Github链接:https://github.com/Wasdns/object-oriented 题目:程序设计第三次作业 程序设计第三次作业附加 我的程序设计第三次作业附加 代码规范 更新时间: ... 
- vue路由异步组件案例
			最近研究了vue性能优化,涉及到vue异步组件.一番研究得出如下的解决方案. 原理:利用webpack对代码进行分割是异步调用组件前提.异步组件在优先级上让位同步组件.下面介绍的是怎么实现异步组件. ... 
