题意:对于若干个闭区间 \([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的更多相关文章

  1. [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 ...

  2. E. Turn Off The TV Educational Codeforces Round 29

    http://codeforces.com/contest/863/problem/E 注意细节 #include <cstdio> #include <cstdlib> #i ...

  3. 越狱Season 1- Episode 22: Flight

    Season 1, Episode 22: Flight -Franklin: You know you got a couple of foxes in your henhouse, right? ...

  4. 30个HTML初学者建议

    The most difficult aspect of running Nettuts+ is accounting for so many different skill levels. If w ...

  5. 设计模式教程(Design Patterns Tutorial)笔记之三 行为型模式(Behavioral Patterns)

    目录 · Strategy · When to use the Strategy Design Pattern? · Sample Code · Observer · When to use the  ...

  6. 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, ...

  7. Educational Codeforces Round 29(6/7)

    1.Quasi-palindrome 题意:问一个字符串(你可以添加前导‘0’或不添加)是否是回文串 思路:将给定的字符串的前缀‘0’和后缀‘0’都去掉,然后看其是否为回文串 #include< ...

  8. 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代

    2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...

  9. Livecoding.tv 现正举行iOS及Android App设计比赛

    近日,Livecoding.tv, 一个为世界各地的程序员提供在线实时交流的平台,在其网站上发布了一篇通知, 宣布从4月15日至5月15日,会为iOS和Android的开发者举办一场本地移动app设计 ...

  10. POJ 1966 Cable TV Network

    Cable TV Network Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 4702   Accepted: 2173 ...

随机推荐

  1. WeetCode3 暴力递归->记忆化搜索->动态规划

    笔者这里总结的是一种套路,这种套路笔者最先是从左程云的b站视频学习到的 本文进行简单总结 系列文章目录和关于我 一丶动态规划的思想 使用dp数组记录之前状态计算的最佳结果,找出当前状态和之前状态的关系 ...

  2. MySQL事务(四大特征)-存储过程

    目录 一:事务 1.四大特性(ACID) 2.事物存在的必要性(真实比喻) 3.如何使用事务 4.开启事务-回滚-确认 二:事务案例实战 1.模拟消费 2.创建 3.插入数据 4.开启事务 5.修改操 ...

  3. python之yaml文件读取封装

    import os import yaml from yamlinclude import YamlIncludeConstructor YamlIncludeConstructor.add_to_l ...

  4. XSS漏洞利用案例实验

    前言 此为XSS漏洞学习笔记,记录XSS的学习过程,方便今后复习使用,有写的不好的地方请见谅,大佬勿喷. GET型XSS利用 攻击流程 攻击实现 以pikachu网站的反射型XSS(GET)为例 攻击 ...

  5. Redis数据结构与对象

    参考<Redis设计与实现> 系列文章目录和关于我 一丶简单动态字符串 当redis需要的不仅仅是一个字符串字面量,而是一个可以被修改的字符串值时,就会使用SDS(simple dynam ...

  6. 读python代码-学到的python函数-1

    1.with open(data_path,'r') as f: with open()是python用来打开本地文件的,他会在使用完毕后,自动关闭文件,无需手动书写close(). 三种打开模式: ...

  7. Node.js躬行记(26)——接口拦截和页面回放实验

    最近在研究 Web自动化测试,之前做了些实践,但效果并不理想. 对于 QA 来说,公司的网页交互并不多,用手点点也能满足.对于前端来说,如果要做成自动化,就得维护一堆的脚本. 当然,这些脚本也可以 Q ...

  8. [常用工具] Caffe ssd常见问题集合

    1 Check failed: a <= b <0 vs -1.19209e-007> 网上办法是注释掉 CHECK_LE(a, b),但是这样会出大问题.解决办法见2. 如果注释掉 ...

  9. .NET6使用NLog向文件、数据库写数据

    1.Nuget 引入 NLog NLog.Web.AspNetCore NLog.Database(写入数据库使用) 2.创建nlog.config 注意数据库连接字符串需要配置TrustServer ...

  10. 基于Udp通讯的Java局域网群聊小程序

    /**基于Udp通讯的Java局域网群聊小程序 */package com.UdpDemo; import java.net.*; import java.awt.*; import java.awt ...