CF1801B题解
CF1801B题解
简化题意:有 n 个商店,每个商店卖 a,b 两种商品,价格分别为 \(a_i,b_i\),你需要在每个商店买一个商品,并且不能在所有商店都买同一种商品,最小化买的最贵的 a 商品和买的最贵的 b 商品的价格差的绝对值。
思路:首先观察到数据范围是 \(n\leqslant5\times10^5\),也是就感觉像个贪心,于是就考虑枚举某一种商品的最大值然后计算答案。我们不妨枚举买的 a 商品的最大值。我们将所有商店按 \(a_i\) 从大到小排序,钦定当前的 \(a_i\) 为 a 商品的最大值,我们发现这时有 2 类 b 。首先是满足 \(a_j>a_i\)的 \(b_j\),接着是所有满足 \(a_j\leqslant a_i\) 的 \(b_j\),然后是 \(a_j<a_i\) 的 \(b_j\)。对于第一类,它们是必须选的,我们记最大值为 \(maxb\) 。对于第二类,会做贡献的肯定是最大的小于等于 \(a_i\) 的 \(b_j\) 和最小的大于等于 \(a_i\) 的 \(b_j\) ,记为 \(maxl\) 和 \(minr\),需注意的是如果没有其他的 \(a_j=a_i\) ,那不能算上对应的 \(b_j\) 的贡献。同时,因为 \(maxl,minr\) 最多只会有一个被选,那么我们也无需担心我们没有购买任何一个 a 商品。
然后我们考虑如何计算答案。首先,如果 \(maxb\geqslant a_i\),这时无论怎么买答案都不会小于 \(maxb-a_i\) ,于是可以直接更新答案。如果 \(maxb<a_i\) 那么当前答案就是 \(\min(a_i-maxl,minr-a_i)\),再更新答案即可。
代码实现的时候,因为是从大到小考虑 \(a_i\),那么 \(maxb\) 显然可以直接维护,然后对于 \(a_j=a_i\) 的部分可以直接扫一遍,剩下部分的可以考虑用 multiset 来查前驱后继,这样就做完了。时间复杂度 \(O(n\log n)\),空间复杂度 \(O(n)\)。
代码:
#include<bits/stdc++.h>
using namespace std;
inline int read(){
int s=0;
char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')s=s*10+(ch^48),ch=getchar();
return s;
}
const int N=500501;
int T,n;
struct node{
int a,b;
}t[N];
multiset<int>s;
inline bool cmp(node a,node b){
return a.a<b.a;
}
int main(){
T=read();
while(T--){
s.clear();
n=read();
for(int i=1;i<=n;i++)t[i].a=read(),t[i].b=read(),s.insert(t[i].b);
sort(t+1,t+n+1,cmp);
int maxn=-1e9,ans=1e9;
t[n+1].a=t[0].a=-1;
for(int i=n;i>=1;i--){
if(t[i].a==t[i+1].a)continue;
int j=i;
while(t[j-1].a==t[i].a)j--;
if(maxn>=t[i].a){
ans=min(ans,maxn-t[i].a);
break;
}
int cur,maxl=-1e9,minr=2e9+1;
for(int k=j;k<=i;k++){
s.erase(s.find(t[k].b));
}
if(j!=i){
for(int k=j;k<=i;k++){
if(t[k].b<=t[i].a&&t[k].b>maxl)maxl=t[k].b;
if(t[k].b>t[i].a&&t[k].b<minr)minr=t[k].b;
}
}
if(s.size()){
set<int>::iterator it=s.lower_bound(t[i].a);
if(it!=s.end()){
minr=min(minr,*it);
}
if(it!=s.begin())it--,maxl=max(maxl,*it);
}
maxl=max(maxl,maxn);
cur=min(t[i].a-maxl,minr-t[i].a);
ans=min(ans,cur);
for(int k=j;k<=i;k++)maxn=max(maxn,t[k].b);
}
printf("%d\n",ans);
}
return 0;
}
CF1801B题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- MarkDown学习笔记1
# MarkDown学习(一级标题)## 标题(二级)### 三级标题#### 四级标题## 字体*Hello,World!斜体***Hello,World!加粗*****Hello,World!加粗 ...
- mysql安装及可视化界面
Mysql下载安装 官网下载链接 https://dev.mysql.com/downloads/mysql/ 可以选择之前的版本 我一开始下的8.0.21但安装的时候报错说找不到VCRUNTIME1 ...
- js 获取指定天数前日期
getBeforeDate(n) {//传入天数 var n = n; var d = new Date(); var year = d.getFullYear(); var mon = d.getM ...
- Git系列 -> git commit 报错 “Invalid syntax in configuration ini file.”
git commit 报错 提示信息为 "Invalid syntax in configuration ini file." 解决办法: 方法一:使用-n or --no-ver ...
- ubuntu上安装meson & 如何使用meson编译C代码
一· 搭建meson环境并简单编译: 1. 什么是meson Meson 旨在开发最具可用性和快速的构建系统.提供简单但强大的声明式语言用来描述构建.原生支持最新的工具和框架,如 Qt5 .代码覆盖率 ...
- Git基础使用和在UE中使用的方法
Git使用介绍 Git使用 1.基础知识 pwd 显示目前的工作目录 print work directory ls 显示当前路径下所有文件 mkdir 产生新的文件夹make directory t ...
- 【python】第二模块 步骤一 第一课、MySQL的介绍
第一课.MySQL的介绍 一.课程介绍 1.1 课程介绍 学习目标 了解关系型数据库的重要性 为什么会出现关系型数据库? 有哪些常见的关系型数据库? 掌握MySQL的安装和配置 怎么安装MySQL数据 ...
- JRebel4.2 使用之前的激活地址失效,需更改新的激活地址
使用 https://jrebel.qekang.com 会报错 把 https://jrebel.qekang.com 换成 http://idea.javatiku.cn/ ,再进行激活,就ok了
- char值转换为int怎么才能不是ASCII值
直接将char类型的变量强制转换为int类型是不行的,那样只会传递变量所对应的ASCII码 怎么才能将char类型转换为int类型呢?String类型的可以通过方法转换为int类型.那是不是可以将ch ...
- 磊磊零基础打卡算法:day18 c++模拟哈希表来模拟散列表
5.21 哈希表 Hash表又称为散列表,一般由Hash函数(散列函数)与链表结构共同实现,与离散化思想类似. 一般要求:防止冲突,便于查询 模拟hash表: 拉链法:两个核心操作insert(),f ...