Description

为了提高智商,锻炼思维能力,奶牛设计了一个猜数游戏。游戏开始前,贝西会在牛棚后面摆上N个数字。所有数字排成一条直线,按次序从1到N编号。每个数字在1到10^9之间,没有两个数字是一样的。

游戏开始后,其他奶牛将会轮流询问贝西Q个问题,每个问题的格式都是一样的:

“位置在Ql到Qr的数字中,最小的数字是多少?”

对每个问题,贝西都会回答一个数字A,不过,她的回答可能是不正确的。请你帮助其他奶牛判断一下,贝西从哪里开始已经出现矛盾了。

Input Format

第一行:两个用空格分开的整数:N和Q,1 ≤ N ≤ 106,1 ≤ Q ≤ 25000

第二行到第Q + 1行:每行三个用空格分开的整数,Ql,Qr和A,表示一个查询,1 ≤ Ql ≤ Qh ≤ N

Output Format

第一行:如果完全没有矛盾,输出0,否则输出最先造成矛盾的查询编号

------------------------------------------------------------------

正解 = 找规律+并查集

Orz 神大胖指导。
正如题目所说,这 n 个数中不会有重复的,
   因此对于相同的值的询问如果不存在交集便是一个矛盾,
   如果存在交集,那这个数必然就在这个区间中,
   但如果之前的询问已覆盖了这个区间
           A:如果询问值比该数小,这是种合法情况,
           因为之前的询问还能覆盖该区间外的地方,
           B:如果询问值比该数大,显然矛盾.
得到一个判断一段查询是否合法的算法:
   将所给的询问按数值排序(从大到小),
   对于同个数值进行合并操作, 
   如不存在交集 =>存在矛盾
   否则对询问交集中是否已被在比该数值大的值所覆盖,
   由于已经按从小到大排过序,如果交集中有值必然比该数值大
   所以,如果区间中不存在未覆盖的位置 = > 存在矛盾
   否则说明至此未产生矛盾:
   对于该同数值的询问的并集中未覆盖的部分进行覆盖
如果进行完所有操作未发现矛盾,则该区间不存在矛盾.
由于仅对区间中的未覆盖的位置进行查询及修改,可以用并查集进行加速.
在上述算法的基础上,我们可以对矛盾区间进行二分查找,不难得到答案.
Ps.笔者打的递归并查集爆(W)栈(T)了(F),不能忍,该模拟栈了- =.
代码如下:

 #include<cstring>
#include<algorithm>
#include<cstdio>
#include<string>
#include<iostream>
#include<queue>
#define INF 99999999
#define min(X,Y) if(X>Y) X=Y
#define max(X,Y) if(X<Y) X=Y
#define N 1000122
#define M 25022
using namespace std;
int f[N],n,Q,mid,ans;
int q[N];
struct Query{
int l,r,v;
}a[M],b[M];
bool cmp(const Query&X,const Query&Y){
return X.v>Y.v;
}
int find(int now){
int tail=;
q[++tail]=now;
while(){
now=q[tail];
if(now==f[now]) break;
q[++tail]=f[now];
}
while(tail) f[q[tail--]]=now;
return now;
}
bool check(){
for(int i=;i<=n+;i++) f[i]=i;
memcpy(b,a,sizeof(Query)*(mid+));
sort(b+,b++mid,cmp);
for(int i=;i<=mid;i++){
int Min=b[i].l,Max=b[i].r;
int L=b[i].l ,R=b[i].r;
for(;i<=mid&&b[i].v==b[i+].v;){
++i;
min(Min,b[i].l);
max(Max,b[i].r);
if(L>b[i].r||R<b[i].l) return false ;
max(L,b[i].l);
min(R,b[i].r);
}
if(find(L)>R) return false ;
for(int k=find(Min);k<=Max;k=f[k])
f[k]=find(k+);
}
return true;
}
int main(){
scanf("%d%d",&n,&Q);
for(int i=;i<=Q;i++)
scanf("%d%d%d",&a[i].l,&a[i].r,&a[i].v);
int Le=,Ri=Q;
while(Ri>=Le){
mid=(Le+Ri)>>;
if(!check()){
Ri=mid-;
ans=mid;
} else Le=mid+;
}
printf("%d",ans);
}

usaco 猜数游戏的更多相关文章

  1. 【BZOJ 1594】 [Usaco2008 Jan]猜数游戏 (二分+并查集)

    1594: [Usaco2008 Jan]猜数游戏 Description 为了提高自己低得可怜的智商,奶牛们设计了一个新的猜数游戏,来锻炼她们的逻辑推理能力. 游戏开始前,一头指定的奶牛会在牛棚后面 ...

  2. (一)Python之猜数游戏

    猜数游戏由简如深的编码学习过程: 3次机会: print('------------------我爱鱼C工作室------------------')count=0while count < 3 ...

  3. 猜数游戏-flag的运用

    package my;import java.util.Scanner;public class MyJava {        public static void main(String[] ar ...

  4. Java课程设计——猜数游戏(201521123111 陈伟泽)

    Java课程设计--猜数游戏(201521123111 陈伟泽) 1.团队课程设计博客链接 博客作业--猜数游戏 2.个人负责模块或任务说明 Answer:一些基础界面的构造,排行榜的构造,用文件录入 ...

  5. JAVA课程设计 猜数游戏 团队

    团队名称,成员介绍 名称: 猜数游戏 成员: 网络1514 201521123086 周颖强 网络1514 201521123087蒋勃超 项目git地址 git.oschina.net/jbc113 ...

  6. BZOJ 2222: [Cqoi2006]猜数游戏【神奇的做法,傻逼题,猜结论】

    2222: [Cqoi2006]猜数游戏 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 604  Solved: 260[Submit][Status ...

  7. 从scratch到python——猜数游戏

    ` 之前讲解了从scratch到python,基于python turtle库的实现,讲解了用scratch和python turtle绘图的实现,以及让小猫动起来和当角色被单击的例子. 本节课讲继续 ...

  8. VBS猜数游戏

    VBS 猜数游戏 2018-11-09  21:19:11 by xutao msgbox "The Swami" ,,"Game" msgbox " ...

  9. 【BZOJ1594】[Usaco2008 Jan]猜数游戏 二分答案+并查集

    [BZOJ1594][Usaco2008 Jan]猜数游戏 Description 为了提高自己低得可怜的智商,奶牛们设计了一个新的猜数游戏,来锻炼她们的逻辑推理能力. 游戏开始前,一头指定的奶牛会在 ...

随机推荐

  1. shipyard docker 管理平台

    终于把shipyard弄好了. 我也是根据shipyard的官方文档,做的.在刚开始的时候觉得好难,也遇到了困难,查看了好多文档 但做完之后发现,只需要几步就能简单的配置成功,就能运行了. 修改tcp ...

  2. 易买网(注册Ajax讲解)

    关于注册(用到Ajax) 运用onblur进行时时刷新 创建所需用的Servlet 好了 Ajax其实不是很难  如果还是不懂可以私信我呦-^^-!

  3. 【转】PL/SQL Developer使用技巧、快捷键

    原文链接:PL/SQL Developer使用技巧.快捷键 1.类SQL PLUS窗口:File->New->Command Window,这个类似于oracle的客户端工具sql plu ...

  4. PHP分页初探 一个最简单的PHP分页代码实现

    PHP分页代码在各种程序开发中都是必须要用到的,在网站开发中更是必选的一项. 要想写出分页代码,首先你要理解SQL查询语句:select * from goods limit 2,7.PHP分页代码核 ...

  5. Oracle课堂实验一“表的使用”代码。

    --创建本地管理表空间CustomerTBSCREATE TABLESPACE CustomerTBS         DATAFILE 'd:\Oracle11\product\11.2.0\ora ...

  6. php单入口session处理

    if (isset($_SERVER['HTTP_HOST'])) { if(!empty($_POST['PHPSESSID'])) session_id($_POST['PHPSESSID']); ...

  7. aspose.cells根据模板导出excel

    又隔十多天没写博客了,最近都在忙项目的事情,公司人事变动也比较大,手头上就又多了一个项目.最近做用aspose.cells根据模板导出excel报价单的功能,顺便把相关的核心记下来,先上模板和导出的效 ...

  8. slivelight5和数据库交互

    最近开始研究sliverlight和数据库交互了,无奈网上资料较少,查阅了大量资料终于成功了,但是我记得还有别的方法,希望大家讨论一下 数据访问层我的用的是ado.net实体数据模型 然后新建了一个w ...

  9. Android开发者指南-方位传感器-Position Sensor

    Android开发者指南-方位传感器-Position Sensor 转载自:http://blog.sina.com.cn/s/blog_48d4913001010zsu.html Position ...

  10. 基于h5+ajax实现的手机定位

    因朋友需要,之前看了下关于h5的手机定位,目前写了个demo在这里贴出来,感兴趣的朋友可以看一下. 目前的版本只是demo,仍有几个问题需要完善一下,问题如下: 1,如何将经纬度等数据发送到被定位人看 ...