Gym 100096D Guessing game

题面

Problem Description

Byteman is playing a following game with Bitman. Bitman writes down some 1 000 000 000-element

sequence of zeros and ones. Byteman’s task is to guess the sequence that Bitman created. He can achieve

this goal by asking Bitman questions of the form: ’What is the parity of the sum of a subsequence of your

sequence, that begins at the b-th element and ends at the e-th element of the sequence?’. After playing

the game for some time, Byteman started suspecting that Bitman was cheating. He would like to know

at which moment did Bitman first answer his question in an inconsistent way, so he asked you for help.

Write a program which:

  • reads a description of Byteman’s questions and Bitman’s answers,

  • computes the greatest number N, for which Bitman’s answers for the first N questions are consistent.

Input

The first line of the input file contains one integer n (0 ≤ n ≤ 100 000), denoting the number of Byteman’s

questions. Each of the following n lines describes one Byteman’s question with corresponding Bitman’s

answer in the form of three positive integers b, e and s (1 ≤ b ≤ e ≤ 1 000 000 000, s ∈ {0, 1}), separated

by single spaces. b and e are the indices of the first and the last element of the subsequence in Byteman’s

question. s = 0 means that Bitman answered that the sum was even and s = 1 — that it was odd.

Output

The first and only line of the output file should contain one integer — the greatest value of N such that

there exists a sequence of zeros and ones that is consistent with Bitman’s answers to first N Byteman’s

questions.

题意

给出一些关系,从l到r的1的个数为奇数还是偶数。问从哪组开始是矛盾的。

考虑一个点不是奇数就是偶数,用一个前缀和的形式表示到i为止的前面所有数i的个数是奇数还是偶数。将一个点拆成两个点。

如果一个点的奇数代表和偶数代表相连说明改组关系与之前的肯定矛盾。

若v==1,则将l-1的奇数代表和r的偶数代表相连,l-1的偶数代表和r的奇数代表相连,表示[l,r]中有改变奇偶性。

若v==1,则将l-1的奇数代表和r的奇数代表相连,l-1的偶数代表和r的偶数代表相连,表示[l,r]中未改变奇偶性。

考虑到b,e很大,用map离散化。

代码

#include <bits/stdc++.h>
using namespace std; int n;
int fa[1000010]; int l[1000010];
int r[1000010];
int v[1000010];
int cnt;
map<int,int> f;
int ans; int find(int k)
{
return fa[k]==k?k:fa[k]=find(fa[k]);
} int main()
{
freopen("game.in","r",stdin);
freopen("game.out","w",stdout); cin>>n;
for (int i=1;i<=n;i++)
{
cin>>l[i]>>r[i]>>v[i];
l[i]--;
if (!f[l[i]]) f[l[i]]=++cnt;
if (!f[r[i]]) f[r[i]]=++cnt;
}
for (int i=1;i<=cnt+cnt;i++) fa[i]=i;
for (int i=1;i<=n;i++)
{
int x=f[l[i]],y=f[r[i]];
if (v[i])
{
if (find(x)==find(y)) break;
ans++;
if (find(y+cnt)!=find(x)) fa[fa[x]]=fa[y+cnt];
if (find(x+cnt)!=find(y)) fa[fa[y]]=fa[x+cnt];
}
else
{
if (find(x)==find(y+cnt)) break;
ans++;
if (find(y)!=find(x)) fa[fa[x]]=fa[y];
if (find(x+cnt)!=find(y+cnt)) fa[fa[y+cnt]]=fa[x+cnt];
}
}
cout<<ans<<endl;
return 0;
}

题目链接

http://codeforces.com/gym/100096/attachments

Gym 100096D Guessing game的更多相关文章

  1. Codeforces Gym 100015G Guessing Game 差分约束

    Guessing Game 题目连接: http://codeforces.com/gym/100015/attachments Description Jaehyun has two lists o ...

  2. 【容斥原理】【推导】【树状数组】Gym - 101485G - Guessing Camels

    题意:给你三个1~n的排列a,b,c,问你在 (i,j)(1<=i<=n,1<=j<=n,i≠j),有多少个有序实数对(i,j)满足在三个排列中,i都在j的前面. 暴力求的话是 ...

  3. GCD Guessing Game Gym - 100085G 猜数字 gcd

    http://codeforces.com/gym/100085/attachments 因为那个数字是一个质数,这样的猜的次数是最多的,所以至少是质数次. 但是如果需要猜2.3,那么可以直接猜6,也 ...

  4. Gym - 100085G - GCD Guessing Game

    原题链接 题意一个数字x在1-n之间,现在猜数字,每次猜一个数字a,告知gcd(x, a)的答案,问最坏情况下需要猜几次 分析 考虑素数.当猜的数为一组素数的乘积时,就可以把这些素数都猜出来.那么答案 ...

  5. ACM: Gym 101047M Removing coins in Kem Kadrãn - 暴力

     Gym 101047M Removing coins in Kem Kadrãn Time Limit:2000MS     Memory Limit:65536KB     64bit IO Fo ...

  6. ACM: Gym 101047K Training with Phuket's larvae - 思维题

     Gym 101047K Training with Phuket's larvae Time Limit:2000MS     Memory Limit:65536KB     64bit IO F ...

  7. ACM: Gym 101047E Escape from Ayutthaya - BFS

    Gym 101047E Escape from Ayutthaya Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%I6 ...

  8. ACM: Gym 101047B Renzo and the palindromic decoration - 手速题

     Gym 101047B  Renzo and the palindromic decoration Time Limit:2000MS     Memory Limit:65536KB     64 ...

  9. 2632: [neerc2011]Gcd guessing game

    2632: [neerc2011]Gcd guessing game Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 144  Solved: 84[S ...

随机推荐

  1. how2j网站前端项目——天猫前端(第一次)学习笔记6

    开始我的订单页面 学着学着,会觉得我这是在干啥呢?我要学的是Java不是吗?怎么要学这么久的前端啊?说实话,我很迷茫,不知道以后的工作具体是做什么?学的这些能用到吗? 不过,还是要把这个项目跟着走完! ...

  2. Dockerfile里指定执行命令用ENTRYPOING和用CMD有何不同?

    结论:运行时机不太一样. RUN是在Build时运行的,先于CMD和ENTRYPOINT.Build完成了,RUN也运行完成后,再运行CMD或者ENTRYPOINT. ENTRYPOINT和CMD的不 ...

  3. c#devexpress GridContorl添加进度条

    demo 的实现图 下边是步骤和代码 1定义 时钟事件,定时的增加进度条的增量. 2:  添加进度条 3;定义字段属性 using System; using System.Collections.G ...

  4. 28335XINTF的简单使用

    28335 XINTF基本特点 一共有三个外部存储区域:区域0(Zone 0),区域6(Zone 6)和区域7(Zone 7).对应的 访问地址为:Zone 0:0x0000_4000-0x0000_ ...

  5. Mac下安装社区版MongoDB

    MongoDB下载地址:https://www.mongodb.com/download-center?_ga=2.98072543.1777419256.1515472368-391344272.1 ...

  6. iOS8 UIAlertView键盘闪一下的问题

    if (SYSTEM_VERSION >= 8.0) { UIAlertController *alertCtrl = [UIAlertController alertControllerWit ...

  7. 还没有写完准备弡上cpickle 还有字典

    #!/usr/bin/python #Filename: cpickle.py import cPickle as p import os shoplistfile="shoplist.da ...

  8. TI and RI

    https://blog.csdn.net/qq_27977257/article/details/70677661 51单片机的串口,是个全双工的串口,发送数据的同时,还可以接收数据.当串行发送完毕 ...

  9. 数据结构:链表 >> 链表按结点中第j个数据属性排序(冒泡排序法)

    创建结点类,链表类,测试类 import java.lang.Object; //结点node=数据date+指针pointer public class Node { Object iprop; p ...

  10. 52ABP视频学习

    https://study.163.com/course/courseMain.htm?courseId=1005208064 网易视频 https://www.52abp.com/ReadWiki/ ...