【[USACO08JAN]haybale猜测Haybale Guessing】
抄题解.jpg
完全完全不会啊,这道题简直太神了
不过抄题解可真开心
首先这道题目保证了每一个位置上的数都是不同的,那么就能得到第一种判断不合法的方式
如果两个区间的最小值一样,但是两个区间的交集为空集,那么就是不合法的
因为最小值肯定来自于同一个位置
之后就是第二种情况
上面那两个红色区间的最小值是\(4\),但是下面那个被完全包含的绿色区间的最小值是\(3\)这显然非常不合法
但是如果是这个样子呢
显然是可以的,因为那些\(3\)可以来自红色区间以外的位置
就有不行了,因为这个时候\(3\)又只能来自于那个较小的绿色区间了,而那个较小的绿色区间又被红色完全覆盖了
这个时候就能得出第二个判断方法
如果最小值相同的区间,其交集被最小值比它的区间的并集覆盖,那么就不合法
所以我们需要覆盖并集,判断交集是否被完全覆盖
显然区间的交集和并集随手就能求出来,但是覆盖这个问题得需要一棵线段树来判断
同时为了方便的进行判断\(2\),我们得让区间的最小值是有序的,所以一个一个扫是行不通了,我们得二分答案,找到最后一个合法的位置\(+1\)就是答案了
代码
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#define LL long long
#define re register
#define maxn 25005
#define min(a,b) ((a)<(b)?(a):(b))
#define max(a,b) ((a)>(b)?(a):(b))
struct Seg
{
int x,y,q;
}a[maxn],b[maxn];
int l[4000005],r[4000005],d[4000005],tag[4000005];
int n,m;
inline int read()
{
char c=getchar();
int x=0;
while(c<'0'||c>'9') c=getchar();
while(c>='0'&&c<='9')
x=(x<<3)+(x<<1)+c-48,c=getchar();
return x;
}
void build(int x,int y,int i)
{
l[i]=x,r[i]=y;
if(x==y) return;
int mid=x+y>>1;
build(x,mid,i<<1),build(mid+1,y,i<<1|1);
}
void clear(int x,int y,int i)
{
d[i]=0,tag[i]=0;
if(x==y) return;
int mid=x+y>>1;
clear(x,mid,i<<1),clear(mid+1,y,i<<1|1);
}
inline void pushdown(int i)
{
if(!tag[i]) return;
tag[i<<1]=tag[i<<1|1]=1;
d[i<<1]=r[i<<1]-l[i<<1]+1;
d[i<<1|1]=r[i<<1|1]-l[i<<1|1]+1;
tag[i]=0;
}
void change(int x,int y,int i)
{
if(x<=l[i]&&y>=r[i])
{
d[i]=r[i]-l[i]+1;
tag[i]=1;
return;
}
pushdown(i);
int mid=l[i]+r[i]>>1;
if(y<=mid) change(x,y,i<<1);
else if(x>mid) change(x,y,i<<1|1);
else change(x,y,i<<1|1),change(x,y,i<<1);
d[i]=d[i<<1]+d[i<<1|1];
}
int query(int x,int y,int i)
{
if(x<=l[i]&&y>=r[i]) return d[i];
pushdown(i);
int mid=l[i]+r[i]>>1;
if(y<=mid) return query(x,y,i<<1);
if(x>mid) return query(x,y,i<<1|1);
return query(x,y,i<<1)+query(x,y,i<<1|1);
}
inline int cmp(Seg A,Seg B)
{
return A.q>B.q;
}
inline int check(int now)
{
for(re int i=1;i<=now;i++)
b[i]=a[i];
std::sort(b+1,b+now+1,cmp);
clear(1,n,1);
int pre=1,nl=b[1].x,nr=b[1].y,Ul=b[1].x,Ur=b[1].y;
for(re int i=2;i<=now;i++)
{
if(b[i].q==b[pre].q)
{
nl=max(nl,b[i].x);
Ul=min(Ul,b[i].x);
Ur=max(Ur,b[i].y);
nr=min(nr,b[i].y);
}
else
{
if(nl>nr) return 0;
if(query(nl,nr,1)==nr-nl+1) return 0;
change(Ul,Ur,1);
pre=i;
nl=Ul=b[i].x,nr=Ur=b[i].y;
}
}
if(nl>nr) return 0;
if(query(nl,nr,1)==nr-nl+1) return 0;
return 1;
}
int main()
{
n=read(),m=read();
for(re int i=1;i<=m;i++) a[i].x=read(),a[i].y=read(),a[i].q=read();
build(1,n,1);
int L=1,R=m;
int ans=0;
while(L<=R)
{
int mid=L+R>>1;
if(check(mid)) L=mid+1,ans=mid;
else R=mid-1;
}
if(ans==m) puts("0");
else printf("%d\n",ans+1);
return 0;
}
【[USACO08JAN]haybale猜测Haybale Guessing】的更多相关文章
- 洛谷 P2898 [USACO08JAN]haybale猜测Haybale Guessing 解题报告
[USACO08JAN]haybale猜测Haybale Guessing 题目描述 给一段长度为\(n\),每个位置上的数都不同的序列\(a[1\dots n]\)和\(q\)和问答,每个问答是\( ...
- [USACO08JAN]haybale猜测Haybale Guessing
题目描述 The cows, who always have an inferiority complex about their intelligence, have a new guessing ...
- python猜数脚本(电脑猜测)(二分法)
# coding=utf-8# 猜数# 记录猜数的过程import randomcom_result=[] #存放电脑结果,数组com_count=0 #存放电脑猜测次数ran=random.ran ...
- [USACO08JAN]Haybale Guessing(LuoguP2898)
The cows, who always have an inferiority complex about their intelligence, have a new guessing game ...
- 题解—P2898 [USACO08JAN]Haybale Guessing G
pre 首先注意一下翻译里面并没有提到的一点,也是让我没看懂样例的一点,就是这个长度为 \(n\) 的数组里面的数各不相同. 有很多人用并查集写的这道题,题解里面也有一些用线段树写的,不过我认为我的做 ...
- POJ 3657 Haybale Guessing(区间染色 并查集)
Haybale Guessing Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2384 Accepted: 645 D ...
- Haybale Guessing
Haybale Guessing Time Limit: 1000MS Memory Limit: 65536K Description The cows, who always ha ...
- [USACO 08JAN]Haybale Guessing
Description The cows, who always have an inferiority complex about their intelligence, have a new gu ...
- poj-3657 Haybale Guessing(二分答案+并查集)
http://poj.org/problem?id=3657 下方有中文版,不想看英文的可直接点这里看中文版题目 Description The cows, who always have an in ...
随机推荐
- Docker学习(四): 操作容器
特别声明: 博文主要是学习过程中的知识整理,以便之后的查阅回顾.部分内容来源于网络(如有摘录未标注请指出).内容如有差错,也欢迎指正! =============系列文章============= 1 ...
- sql sever 执行较大的文件脚本
1.用管理员身份打开cmd工具 2.执行命令 osql -S localhost -U sa -P 123456 -i D:/test.sql -S 服务器地址 本地可简写 . -U 用户名 -P ...
- 常见IT英语短语一
SSO (Single sign-on)单点登陆. aspect-oriented programming,AOP面向切面. CORS:Cross-origin resource sharing跨域资 ...
- hadoop start-all.sh报错JAVA_HOME is not set and could not be found.
原文 错误:JAVA_HOME is not set and could not be found,可能是因为JAVA_HOME环境没配置正确,还有一种情况是即使各结点都正确地配置了JAVA_HOME ...
- Class.forName("com.mysql.jdbc.Driver")找不到类
解决方法: 如果是java项目,只需要引入mysql-connector-java-8.0.13.jar就可以运行java项目. 建的如果是web工程,需要把mysql-connector-java- ...
- Angular中EventEmitter不是泛型类型
今天在做angular发射数据时,报错:EventEmitter不是泛型类型, 当时第一点就想到是不是没有引入,一看引入了 后面看api文档发现引入错了,其实是引入下面的 可能是之前快捷输入时,IDE ...
- CSS,js,html
图片盗链问题使用以下meta标签解决 <meta name="referrer" content="never"> Chrome 中文界面下默认会将 ...
- BZOJ2229: [Zjoi2011]最小割(最小割树)
传送门 最小割树 算法 初始时把所有点放在一个集合 从中任选两个点出来跑原图中的最小割 然后按照 \(s\) 集合与 \(t\) 集合的归属把当前集合划分成两个集合,递归处理 这样一共跑了 \(n − ...
- 前端之困 · XSS CookBook
方法论 发掘漏洞的时间要具体到是检测什么目标了,找 Google 的,和找腾讯的时间肯定不会一样. 至于是如何发现的,不同类型的 XSS 漏洞,可能不尽相同. 反射型 以及一些 DOM 型,一般建议是 ...
- css 动画中 ease,seae-in,ease-in-out,ease-out,效果区别
linear 规定以相同速度开始至结束的过渡效果(等于 cubic-bezier(0,0,1,1)).(匀速) ease 规定慢速开始,然后变快,然后慢速结束的过渡效果(cubic-bezier(0. ...