CF863E - Turn Off The TV
题意:对于若干个闭区间 \([l_i,r_i]\),它们构成了一个集合 \(\bigcup_{i\le n}{[l_i,r_i]}\),求一个 \(k\),使得 \(\bigcup_{i\le n}{[l_i,r_i]}=\bigcup_{i\le n,i\ne k}{[l_i,r_i]}\)。
我们可以区间覆盖,首先我们考虑如果只考虑整点的效果。那么就是离散化,在 \(l\) 和 \(r\) 上进行差分标记,然后前缀和求出每个点被覆盖的次数。如果一个区间覆盖的所有位置都被覆盖 \(2\) 次以上,那么就可以选择这个区间。
但是现在我们需要的是实数轴上的区间,如何处理呢?比如说在整点覆盖中,\([1,2]\) 和 \([3,4]\) 就覆盖了 \(1\sim4\) 的所有点,但在实轴上,\(2.5\) 没有被覆盖。
拆点法
我们可以通过所有坐标集体乘 \(2\) 给 \((a,a+1)\) 这个区间建立一个虚拟的点 \(2a+1\),在离散化的同时将 \(2l\pm 1\) 和 \(2r\pm 1\) 四个点一起离散化进去,从而我们就把实轴区间覆盖问题转化为整点区间覆盖问题。
这里没有使用比较方便的区间差分,而是使用了线段树实现区间加/查询。
#include<bits/stdc++.h>
using namespace std;
#define rd(i,n) for(int i=0;i<n;i++)
#define rp(i,n) for(int i=1;i<=n;i++)
#define rep(i,a,b) for(int i=a;i<=b;i++)
#define per(i,a,b) for(int i=max(a,b);i>=min(a,b);i--)
#define st string
#define vt vector
#define pb push_back
//#define int long long
typedef long long ll;
typedef long double ld;
typedef pair<int,int> pii;
typedef pair<ll,ll> pll;
int q[1200005];
struct node{
int l,r,s,tg;
}sg[4800005];
inline void init(int i,int l,int r){
sg[i].l=l,sg[i].r=r,sg[i].s=0;
if(l==r)return (void)(sg[i].s=q[l]);
init(i<<1,l,l+r>>1);
init(i<<1|1,(l+r>>1)+1,r);
sg[i].s=min(sg[i<<1].s,sg[i<<1|1].s);
}
inline int qry(int i,int l,int r){
if(sg[i].l>r||sg[i].r<l)return 1e9;
if(sg[i].l>=l&&sg[i].r<=r)return sg[i].s;
return min(qry(i<<1,l,r),qry(i<<1|1,l,r));
}
int n,l[200005],r[200005],v[1200005],m;
signed main(){
cin>>n;
rp(i,n)cin>>l[i]>>r[i];
rp(i,n)v[++m]=l[i],v[++m]=r[i],v[++m]=l[i]+1,v[++m]=l[i]-1,v[++m]=r[i]+1,v[++m]=r[i]-1;
sort(v+1,v+1+m);
m=unique(v+1,v+1+m)-v-1;
rp(i,n){
l[i]=lower_bound(v+1,v+1+m,l[i])-v;
r[i]=lower_bound(v+1,v+1+m,r[i])-v;
q[l[i]]++;
q[r[i]+1]--;
}
rp(i,m)q[i]+=q[i-1];
init(1,1,m);
rp(i,n){
if(qry(1,l[i],r[i])>1){
cout<<i<<endl;
return 0;
}
}cout<<-1<<endl;
return 0;
}
//Crayan_r
开闭
我们可以将区间转化为左开右闭的形式,在修改的时候减少一位右端点。
这样有什么好处呢?假如我们当前覆盖的区间是 \([l,r]\),则实际上被标记上的整点区间是 \([l-1,r-1]\)。
但是我们查询的时候查询的是 \([l,r]\),这样,除非原先的右端点在 \(l+1\) 的位置,否则就不会覆盖到 \(l\),也就解决了中间实数没有覆盖的问题。右边也同理。
#include "bits/stdc++.h"
using namespace std;
#define rep(i,n) for(int (i)=0;(i)<(int)(n);++(i))
#define rer(i,l,u) for(int (i)=(int)(l);(i)<=(int)(u);++(i))
#define reu(i,l,u) for(int (i)=(int)(l);(i)<(int)(u);++(i))
static const int INF = 0x3f3f3f3f; static const long long INFL = 0x3f3f3f3f3f3f3f3fLL;
typedef vector<int> vi; typedef pair<int, int> pii; typedef vector<pair<int, int> > vpii; typedef long long ll;
template<typename T, typename U> static void amin(T &x, U y) { if (y < x) x = y; }
template<typename T, typename U> static void amax(T &x, U y) { if (x < y) x = y; }
int main() {
int n;
while (~scanf("%d", &n)) {
vector<int> L(n);
vector<int> R(n);
for (int i = 0; i < n; ++ i)
scanf("%d%d", &L[i], &R[i]), -- L[i];
vector<int> values;
rep(i, n) {
values.push_back(L[i]);
values.push_back(R[i]);
}
sort(values.begin(), values.end());
values.erase(unique(values.begin(), values.end()), values.end());
int X = (int)values.size();
vector<int> add(X + 1);
rep(i, n) {
int l = (int)(lower_bound(values.begin(), values.end(), L[i]) - values.begin());
int r = (int)(lower_bound(values.begin(), values.end(), R[i]) - values.begin());
++ add[l], -- add[r];
}
rep(i, X)
add[i + 1] += add[i];
vector<int> sum(X + 1);
rep(i, X)
sum[i + 1] = sum[i] + (add[i] >= 2);
int ans = -1;
rep(i, n) {
int l = (int)(lower_bound(values.begin(), values.end(), L[i]) - values.begin());
int r = (int)(lower_bound(values.begin(), values.end(), R[i]) - values.begin());
if (sum[r] - sum[l] == r - l) {
ans = i;
break;
}
}
printf("%d\n", ans == -1 ? ans : ans + 1);
}
return 0;
}
CF863E - Turn Off The TV的更多相关文章
- [Codeforces 863E]Turn Off The TV
Description Luba needs your help again! Luba has n TV sets. She knows that i-th TV set will be worki ...
- E. Turn Off The TV Educational Codeforces Round 29
http://codeforces.com/contest/863/problem/E 注意细节 #include <cstdio> #include <cstdlib> #i ...
- 越狱Season 1- Episode 22: Flight
Season 1, Episode 22: Flight -Franklin: You know you got a couple of foxes in your henhouse, right? ...
- 30个HTML初学者建议
The most difficult aspect of running Nettuts+ is accounting for so many different skill levels. If w ...
- 设计模式教程(Design Patterns Tutorial)笔记之三 行为型模式(Behavioral Patterns)
目录 · Strategy · When to use the Strategy Design Pattern? · Sample Code · Observer · When to use the ...
- English trip V1 - 6.Accidents Happen! 发生意外! Teacher:Corrine Key: 过去进行时 was or were + Ving
In this lesson you will learn to talk about past occurences. 过去进行时 课上内容(Lesson) C: Hi, Loki! L: Hi, ...
- Educational Codeforces Round 29(6/7)
1.Quasi-palindrome 题意:问一个字符串(你可以添加前导‘0’或不添加)是否是回文串 思路:将给定的字符串的前缀‘0’和后缀‘0’都去掉,然后看其是否为回文串 #include< ...
- 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代
2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...
- Livecoding.tv 现正举行iOS及Android App设计比赛
近日,Livecoding.tv, 一个为世界各地的程序员提供在线实时交流的平台,在其网站上发布了一篇通知, 宣布从4月15日至5月15日,会为iOS和Android的开发者举办一场本地移动app设计 ...
- POJ 1966 Cable TV Network
Cable TV Network Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 4702 Accepted: 2173 ...
随机推荐
- TypeScript 之 Type
Type 描述:全称叫做 '类型别名',为类型字面量提供名称.比 Interface 支持更丰富的类型系统特性. Type 与 Interface 区别 Interface 只能描述对象的形状,Typ ...
- go-carbon 1.5.3 版本发布, 修复已知 bug 和新增俄罗斯语翻译文件
carbon 是一个轻量级.语义化.对开发者友好的golang时间处理库,支持链式调用. 目前已被 awesome-go 收录,如果您觉得不错,请给个star吧 github.com/golang-m ...
- docker部署项目
@ 目录 前言 一.下载安装docker: 1.前提工作 1.1 查看linux版本 1.2 yum包更新到最新 1.3 安装工具包 1.4 设置yum源并更新yum包索引 2.安装docker 2. ...
- 使用PyLint分析评估代码质量
什么是PyLint PyLint是一款用于评估Python代码质量的分析工具,它诞生于2003年,其最初十年的主要作者和维护者是Sylvain Thénault.PyLint可以用来检查代码是否错误. ...
- Burp Suite
Burp Suite proxy代理 1.首先在浏览器中设置代理配置 火狐浏览器先点击右上角三个杠--选项--常规--网络设置 2.打开Burp Suite进行抓包 Proxy代理--options中 ...
- SQL一文入门助记
什么是SQL SQL(Structured Query Language)是用于操作数据库的语言.一个博客有许多网站,一个游戏要储存许多游戏的账号密码,这些都离不开数据库操作. 关系型数据库与NoSQ ...
- java中对象存在形式
本文主要讲述jvm中对象的存储形式: class Cat{ String name; int age; String color; // 行为 } 依据Cat类创建对象 public class Ob ...
- java中加号的用法
注意java中+号的使用 public class Add { public static void main(String[] args) { System.out.println(100+80); ...
- Python全栈工程师之从网页搭建入门到Flask全栈项目实战(7) - 在线问答系统
1.项目源码/业务逻辑 百度网盘链接:链接:https://pan.baidu.com/s/13VNfrSJE6vcL3HP1J5T8ew 提取码:00s0,项目业务逻辑自行阅读 2.项目搭建 点击新 ...
- Law of Iterated Expectations & Covariance
Law of Iterated Expectations \(E[Y] = E_X[E[Y |X]].\) The notation \(E_X[.]\) indicates the expectat ...