CF Hello2020 D. New Year and Conference
D. New Year and Conference
题意
有\(2n\)个区间,分别为\([sa_1,ea_1],[sb_1,eb_1],[sa_2,ea_2],[sb_2,eb_2],\cdots,[sa_n,ea_n],[sb_n,eb_n]\),每两个区间为一对,共\(n\)对区间。一对中的两个区间绑定在一起,从n对中选出一个子集。存在一种情况是:子集中某个系列(a或b)区间有区间交,而另外一个系列的区间没有区间交。如果这个情况发生在某个子集中,则输出NO,否则输出YES
分析
先考虑a系列区间交的所有可能,枚举交点,将包含该交点的所有a区间都放到数轴上,同时把对应的b区间也放在数轴上,那么这些b区间中两两之间也必须在某点交。
做法是按照a系列区间的左右端点,存放区间编号于vector中,从左到右扫交点,同时将b区间加到线段树上,并同时判断当前加的b区间是否与之前的b区间都交,不是的话输出NO。
const int inf = 0x3f3f3f3f;
const int N = 400010;
int n;
struct SegTree{
int l,r;
int mx,lazy;
}t[N*4];
struct node{
int l,r,id;
}a[N],b[N];
vector<int> l[N],r[N],alls;
void build(int p,int l,int r){
t[p].l = l;t[p].r = r;
if(l == r){
t[p].mx = t[p].lazy = 0;
return;
}
int mid = l + r >> 1;
build(p*2,l,mid);
build(p*2+1,mid+1,r);
t[p].mx = t[p].lazy = 0;
}
void pushdown(int p){
if(t[p].lazy){
t[p*2].mx += t[p].lazy;
t[p*2+1].mx += t[p].lazy;
t[p*2].lazy += t[p].lazy;
t[p*2 + 1].lazy += t[p].lazy;
t[p].lazy = 0;
}
}
int ask(int p,int l,int r){
if(t[p].l >= l && t[p].r <= r){
return t[p].mx;
}
pushdown(p);
int mid = t[p].l + t[p].r >> 1;
int res = 0;
if(mid >= l)res = max(res,ask(p*2,l,r));
if(mid < r)res = max(res,ask(p*2+1,l,r));
return res;
}
void add(int p,int l,int r,int val){
if(t[p].l >= l && t[p].r <= r){
t[p].mx += val;
t[p].lazy += val;
return;
}
pushdown(p);
int mid = t[p].l + t[p].r >> 1;
if(mid >= l)add(p*2,l,r,val);
if(mid < r)add(p*2+1,l,r,val);
t[p].mx = max(t[p*2].mx,t[p*2+1].mx);
}
bool check(node *a,node *b){
int len = alls.size();
build(1,1,len);
for(int i=1;i<=len;i++){
l[i].clear();
r[i].clear();
}
for(int i=1;i<=n;i++){
l[a[i].l].push_back(i);
r[a[i].r].push_back(i);
}
int sz = 0;
for(int i=1;i<=len;i++){
for(int j=0;j<l[i].size();j++){
int id = l[i][j];
//把id铺上
int L = b[id].l, R = b[id].r;
//[L,R] 之间最大值必须为sz
int res = ask(1,L,R);
if(res != sz) return false;
add(1,L,R,1);
sz++;
}
for(int j=0;j<r[i].size();j++){
int id = r[i][j];
int L = b[id].l, R= b[id].r;
add(1,L,R,-1);
sz--;
}
}
return true;
}
int getId(int x){
return lower_bound(alls.begin(),alls.end(),x) - alls.begin() + 1;
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d%d%d%d",&a[i].l,&a[i].r,&b[i].l,&b[i].r);
alls.push_back(a[i].l);
alls.push_back(a[i].r);
alls.push_back(b[i].l);
alls.push_back(b[i].r);
a[i].id = i;
b[i].id = i;
}
sort(alls.begin(),alls.end());
alls.erase(unique(alls.begin(),alls.end()),alls.end());
for(int i=1;i<=n;i++){
a[i].l = getId(a[i].l);
a[i].r = getId(a[i].r);
b[i].l = getId(b[i].l);
b[i].r = getId(b[i].r);
}
int c1 = check(a,b);
int c2 = check(b,a);
if(c1 && c2){
puts("YES");
}else puts("NO");
return 0;
}
CF Hello2020 D. New Year and Conference的更多相关文章
- memory-based 协同过滤(CF)方法
协同过滤(collaborative filtering,CF)算法主要分为memory-based CF 和 model-based CF,而memory-based CF 包括user-based ...
- Hello2020(前四题题解)
Hello,2020!新的一年从快乐的掉分开始…… 我在m3.codeforces.com这个镜像网站中一开始还打不开D题,我…… 还有话说今天这场为什么那么多二分. 比赛传送门:https://co ...
- ENode框架Conference案例分析系列之 - 文章索引
ENode框架Conference案例分析系列之 - 业务简介 ENode框架Conference案例分析系列之 - 上下文划分和领域建模 ENode框架Conference案例分析系列之 - 架构设 ...
- ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'
凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...
- International Conference for Smart Health 2015 Call for Papers
Advancing Informatics for healthcare and healthcare applications has become an international researc ...
- Call for Papers IEEE/ACM International Conference on Advances in Social Network Analysis and Mining (ASONAM)
IEEE/ACM International Conference on Advances in Social Network Analysis and Mining (ASONAM) 2014 In ...
- Call for Papers International Conference for Smart Health (ICSH) 2014
Call for PapersInternational Conference for Smart Health (ICSH) 2014 Beijing, China July 10-11, 2014 ...
- ENode框架Conference案例分析系列之 - 业务简介
前言 ENode是一个应用开发框架.通过ENode,我们可以方便的开发基于DDD+CQRS+EventSourcing+EDA架构的应用程序.之前我已经写了很多关于ENode的架构以及设计原理的文章, ...
- ENode框架Conference案例分析系列之 - 上下文划分和领域建模
前面一片文章,我介绍了Conference案例的核心业务,为了方便后面的分析,我这里再列一下: 业务描述 Conference是这样一个系统,它提供了一个在线创建会议以及预订会议座位的平台.这个系统的 ...
随机推荐
- vue中添加文字或图片水印
首先引用warterMark.js,内容如下 'use strict' var watermark = (className,str,type) => { let dom = document. ...
- Command2
Ctrl^c 强制终止当前命令执行 chmod {ugoa(user/group/other/all)}{+-=(wrx权限增删改)} 文件或目录 权限 对文件 对目录 r 可查看文件内容 可以列出目 ...
- SqlLoad的简单使用
sqlload的简单使用: 能实现: 快速导入大量数据 1.先安装oracle 客户端机器.有点大,600M+, 2.安装时选择管理员安装(1.1g) 3.第三步的时候我的出错了.说是环境变量校验不通 ...
- 一次snapshot迁移引发的Hbase RIT(hbase2.1.0-cdh6.3.0)
1. 问题起因 通过snapshot做跨集群数据同步时,在执行拷贝脚本里没有指定所有者及所有组,导致clone时没有权限,客户端卡死.master一直报错,经过一系列操作后,导致RIT异常. 2. 异 ...
- CSAPP:Lab0 -Docker搭建纯净Linux环境
1. 安装docker 在mac-os下我们可以利用homebrew很容易的安装docker. brew install docker 当然去官网下载也很容易 Empowering App Devel ...
- HTML基础复习3
CSS 可以理解为对HTML的一种补充 CSS由两部分组成:选择器.声明,声明中包含属性和值 CSS中的选择器 HTML标签选择器 类选择器 在标签上使用class属性为标签起个类名,在CSS中使用. ...
- Java流程控制与Scanner类的使用
Java流程控制与Scanner类的使用 Scanner类 Scanner类可以使程序接受键盘输入,实现人机交互 一个完整的Scanner的使用例子: //创建一个扫描器对象,用于接收键盘数据 Sca ...
- 微信小程序腾讯地图SDK使用方法
一.本篇文章主要知识点有以下几种: 1.授权当前位置 2.map组件的使用 3.腾讯地图逆地址解析 4.坐标系的转化 二.效果如下: 三.WXML代码 <map id="map&quo ...
- C++ unordered_map/unordered_set 自定义键类型
1. unordered_map 和 unordered_set template < class Key, // unordered_map::key_type class T, // uno ...
- 异步日志 Loguru
https://mp.weixin.qq.com/s/hy68s610B9GbL_wgwTn7nA 更优美的python日志管理库Loguru Asynchronous, Thread-safe, M ...