Description

隔壁村的阿黑的Dog没有跑, 但Dog已经15岁了, 相当于人类达到了79岁.

为了防止Dog患上犬类认知障碍 (Canine cognitive dysfunction, CCD), 阿黑决定陪Dog玩猜数游戏.

游戏开始前,阿黑会在Dog后面摆上\(N\)个数字. 所有数字排成一条直线,按次序从\(1\)到\(N\)编号,每个位置的数字均不同.

游戏开始后,Dog将会询问阿黑\(Q\)个问题,每个问题的格式都是一样的:

"位置在\(l\)到\(r\)的数字中,最小的数字是多少?"

对每个问题,阿黑都会回答一个数字\(A\). 但阿黑的回答可能不正确.

年迈的Dog想知道阿黑从哪里开始已经出现了矛盾, 可惜的是, Dog其实已经患上了严重的犬类认知障碍, 于是这就成了一道机考题.

Input

输入的第一行有两个用空格分开的整数\(N\)和\(Q\), 含义如上.

接下来\(Q\)行, 每行有三个用空格分开的整数\(l, r, A\), 含义如上.

Output

如果完全没有矛盾,输出\(0\),否则输出最先造成矛盾的问题编号

Sample Input

20 4

1 10 7

5 19 7

3 12 8

11 15 12

Sample Output

3

这道题我们可以这样想,如果我们按照询问数值的某种顺序来排序,是不是会好做一点。这个时候我们只要套上一个二分,一样可以求出最小是哪个询问不满足。

如果我们从小到大排序,由于每个位置的值不同,数值相同的区间要两两相交才行。并且如果这些区间的并中包含之前某个数值区间的交也不行(稍微YY下吧)。这个算法可以用set写,但是很复杂啊。

但是我们可以从大到小排序,过程刚好相反。数值相同的区间要两两相交才行,并且这些区间的交不能包含别的区间。这个我们可以用并查集实现。一段区间表示一个集合,集合的代表元便是区间右端点\(+1\)(方便实现)。

具体实现看代码:

#include<set>
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstdlib>
using namespace std; #define inf (1<<29)
#define maxn (1000010)
int ans,N,Q,father[maxn],tmp[maxn],cnt;
struct node
{
int L,R,V,id;
friend inline bool operator <(const node &a,const node &b) { return a.V > b.V; }
inline void read(int i) { scanf("%d %d %d",&L,&R,&V); id = i; }
}query[maxn]; inline int find(int x)
{
for (;x != father[x];x = father[x]) tmp[++cnt] = x;
while (cnt) father[tmp[cnt--]] = x;
return x;
} inline bool check(int mid)
{
for (int i = 1;i <= N+1;++i) father[i] = i;
for (int i = 1,j;i <= Q;i = j)
{
int jl = -inf,jr = inf,bl = inf,br = -inf;
for (j = i;j <= Q&&query[j].V == query[i].V;++j)
{
if (query[j].id > mid) continue;
jl = max(jl,query[j].L); bl = min(bl,query[j].L);
jr = min(jr,query[j].R); br = max(br,query[j].R);
if (jl > jr) return false;
}
if (jl == -inf) continue;
if (find(jl)-1 >= jr) return false;
int f = find(br+1);
for (int k = find(bl);k <= br;++k) father[k] = f;
}
return true;
} inline void work()
{
int l = 1,r = Q,mid;
while (l <= r)
{
mid = (l+r) >> 1;
if (check(mid)) l = mid + 1;
else r = mid - 1,ans = mid;
}
} int main()
{
freopen("1586.in","r",stdin);
freopen("1586.out","w",stdout);
scanf("%d %d",&N,&Q);
for (int i = 1;i <= Q;++i) query[i].read(i);
sort(query+1,query+Q+1);
work(); printf("%d",ans);
fclose(stdin); fclose(stdout);
return 0;
}

sjtu1586 Dog的更多相关文章

  1. [ZigBee] 12、ZigBee之看门狗定时器——饿了就咬人的GOOD DOG

    引言:硬件中的看门狗,不是门卫的意思,而是一只很凶的狗!如果你不按时喂它,它就会让系统重启!这反而是我们想要的功能~ 1.看门狗概述 看门狗定时器(WDT,Watch Dog Timer)是单片机的一 ...

  2. 斑点检测(LoG,DoG)(下)

    斑点检测(LoG,DoG)(下) LoG, DoG, 尺度归一化 上篇文章斑点检测(LoG,DoG)(上)介绍了基于二阶导数过零点的边缘检测方法,现在我们要探讨的是斑点检测.在边缘检测中,寻找的是二阶 ...

  3. 斑点检测(LoG,DoG) [上]

    斑点检测(LoG,DoG) [上] 维基百科,LoG,DoG,DoH 在计算机视觉中,斑点检测是指在数字图像中找出和周围区域特性不同的区域,这些特性包括光照或颜色等.一般图像中斑点区域的像素特性相似甚 ...

  4. ural 1246. Tethered Dog

    1246. Tethered Dog Time limit: 1.0 secondMemory limit: 64 MB A dog is tethered to a pole with a rope ...

  5. Cat VS Dog

    Cat VS Dog Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 125536/65536 K (Java/Others)Total ...

  6. DoG 、Laplacian、图像金字塔详解

    DoG(Difference of Gaussian) DoG (Difference of Gaussian)是灰度图像增强和角点检测的方法,其做法较简单,证明较复杂,具体讲解如下: Differe ...

  7. HDU 3289 Cat VS Dog (二分匹配 求 最大独立集)

    题意:每个人有喜欢的猫和不喜欢的狗.留下他喜欢的猫他就高心,否则不高心.问最后最多有几个人高心. 思路:二分图求最大匹配 #include<cstdio> #include<cstr ...

  8. 编写一个Animal类,具有属性:种类;具有功能:吃、睡。定义其子类Fish 和Dog,定义主类E,在其main方法中分别创建其对象并测试对象的特性。

    package animal; public class Animal { //成员属性 private String kind; public String getKind() { return k ...

  9. SIFT算法:DoG尺度空间生产

    SIFT算法:DoG尺度空间生产  SIFT算法:KeyPoint找寻.定位与优化 SIFT算法:确定特征点方向  SIFT算法:特征描述子 目录: 1.高斯尺度空间(GSS - Gauss Scal ...

随机推荐

  1. Matlb中break 和continue 语句

    有两个附加语句可以控制while 和for 循环:break 和continue 语句. break 语句可以中止循环的执行和跳到end 后面的第一句执行,而continue 只中止本次循环,然后返回 ...

  2. pat 1006 Sign In and Sign Out (25)

    At the beginning of every day, the first person who signs in the computer room will unlock the door, ...

  3. Ceph Newstore存储引擎介绍

    在Ceph被越来越多地应用于各项存储业务过程中,其性能及调优策略也成为用户密切关注讨论的话题,影响性能表现关键因素之一即OSD存储引擎实现:Ceph基础组件RADOS是强一致.对象存储系统,其OSD底 ...

  4. scala学习笔记:函数与方法

    http://stackoverflow.com/questions/2529184/difference-between-method-and-function-in-scala A Functio ...

  5. h2database源码浅析:TransactionMap、MVMap、MVStore

    TransactionStore:A store that supports concurrent MVCC read-committed transactions. TransactionStore ...

  6. c#调用c++ dll(二)

    当对c++几种调用方式有了解以后我们可以试着写个c++动态连接库了,我们现在来写个简单的c++求和函数并把它封装成dll,供以后的c#调用 我们写dll的时候,个人认为,要写就要把dll写好,写标准, ...

  7. JQuery里的原型prototype分析

    在 JavaScript 中,每个函数对象都有一个默认的属性 prototype,称为函数对象的原型成员,这个属性指向一个对象,称为函数的原型对象,当我们每定义了一个函数的时候,JavaScript ...

  8. IOS之swift第一课基础代码

    import Foundation //import Foundation 导入模块,专业术语也是导入 包,库的 意思. var str = "Hello World" //声明一 ...

  9. C++中各种<string,T>关联方式的速度对比

    把<string,T>(T为任意类型)关联起来,是很常见的需求.如笔者最近要做一个贝叶斯算法的垃圾邮件过滤器,就需要把每个单词与频率对应起来,做成一个表.而当单词很多时,对于每个单词做一遍 ...

  10. C++异常处理(Exception Handling)

    在C++中引入了三种操作符来处理程序的出错情况,分别是:try  , throw  ,  catch 1.基本的用法如下: try{ //code to be tried throw exceptio ...