POJ 1733 Parity game 【带权并查集】+【离散化】
<题目链接>
题目大意:
一个由0,1组成的序列,每次给出一段区间的奇偶,问哪一条信息不合法。
解题分析:
我们用s[i]表示前i个数的前缀和,那么a b even意味着s[b]和s[a-1]的奇偶性相同。a b odd意味着s[b]与s[a-1]的奇偶性不同。于是我们根据奇偶性的不同,用并查集依次处理他们之间的关系。当某条信息出现与并查集中记录的信息不符合时,则此信息不合法。
由于该序列的长度达到了1e9,并且查询次数只有5000次,所以我们需要对查询的区间进行离散化,否则存不下,数据比较小,用map离散化即可,也不会很慢。
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <map>
using namespace std; #define RP(i,s,t) for(int i=s;i<=t;i++)
#define fastIO ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
const int N = 1e4 + ; int n, m, tot,fa[N + ], w[N + ];
map<int,int>mp; int find(int x){
if(x==fa[x])return x;
int tmp=fa[x];
fa[x]=find(fa[x]);
w[x]=(w[x]+w[tmp]+)%; //带权并查集关系的转移
return fa[x];
}
inline bool Union(int a,int b,int x){
int ra=find(a),rb=find(b);
if(ra!=rb){
fa[ra]=rb;
w[ra]=(w[a]-w[b]+x+)%;
}else{
if((w[a]-w[b]+)%!=x)return false; //与之前建立的关系奇偶性不符,则表示出现冲突
}return true;
}
int main() {
fastIO
cin >> n >> m;
RP(i, , N + ) fa[i] = i, w[i] = ;
int ans=;
RP(i,,m){
int a,b;string s;
cin>>a>>b>>s;--a; //因为根据的是前缀和的奇偶性,所以这里a要记得-1
if(!mp[a])mp[a]=++tot; //map用来离散化
if(!mp[b])mp[b]=++tot;
int k=(s=="odd")?:; //odd才是奇,容易搞错
if(Union(mp[a],mp[b],k))ans++;
else break;
}cout<<ans<<'\n';
}
2018-10-02
POJ 1733 Parity game 【带权并查集】+【离散化】的更多相关文章
- POJ 1733 Parity game (带权并查集)
		
题意:有序列A[1..N],其元素值为0或1.有M条信息,每条信息表示区间[L,R]中1的个数为偶数或奇数个,但是可能有错误的信息.求最多满足前多少条信息. 分析:区间统计的带权并查集,只是本题中路径 ...
 - POJ 1773 Parity game 带权并查集
		
分析:带权并查集,就是维护一堆关系 然后就是带权并查集的三步 1:首先确定权值数组,sum[i]代表父节点到子节点之间的1的个数(当然路径压缩后代表到根节点的个数) 1代表是奇数个,0代表偶数个 2: ...
 - poj 1733 Parity game(带权并查集+离散化)
		
题目链接:http://poj.org/problem?id=1733 题目大意:有一个很长很长含有01的字符串,长度可达1000000000,首先告诉你字符串的长度n,再给一个m,表示给你m条信息, ...
 - URAL - 1003:Parity (带权并查集&2-sat)
		
Now and then you play the following game with your friend. Your friend writes down a sequence consis ...
 - POJ 1182 食物链 【带权并查集】
		
<题目链接> 题目大意: 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我 ...
 - POJ 1182 食物链  (带权并查集)
		
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 78551 Accepted: 23406 Description ...
 - POJ 1182 食物链 【带权并查集/补集法】
		
动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到底是哪一种.有人用两种说 ...
 - poj 1182 食物链【带权并查集】
		
设相等的边权为0,吃的边权为,被吃的边权为2,然后用带权并查集在%3的意义下做加法即可 关系为简单环的基本都可以用模环长的方式是用带权并查集 #include<iostream> #inc ...
 - A Bug's Life POJ - 2492 (种类或带权并查集)
		
这个题目的写法有很多,用二分图染色也可以写,思路很好想,这里我们用关于并查集的两种写法来做. 题目大意:输入x,y表示x和y交配,然后判断是否有同性恋. 1 带权并查集: 我们可以用边的权值来表示一种 ...
 - poj1733(带权并查集+离散化)
		
题目链接:http://poj.org/problem?id=1733 题意:给定由0.1组成的数串长度n,询问次数m,每次询问给出a,b,s,表示区间[a,b]内1的数量为s(odd-奇数或even ...
 
随机推荐
- swift 实践- 02 -- 自定义cell 的简单使用
			
import UIKit class MyTableViewCell: UITableViewCell { var imageV: UIImageView? var titleLabel: UILab ...
 - STM32应用实例十四:利用光敏二极管实现光度测量
			
最近我们在开发臭氧发生器时,需要监测生成的臭氧的浓度,于是想到使用光度计来测量.因为不同浓度的臭氧对管的吸收作用是不相同的,于是检测光照强度的变化就可以得到相应的浓度数据. 1.硬件设计 此次光照度检 ...
 - Confluence 6 从站点首页集中访问面板
			
如果你选择设置一个页面为你的站点主页面,但是你还是希望你的用户能够访问 Confluence 的主面板,你可以将主面板的连接添加到应用导航(Application Navigator)中. 希望添加 ...
 - 解决在编程方式下无法访问Spark Master问题
			
我们可以选择使用spark-shell,spark-submit或者编写代码的方式运行Spark.在产品环境下,利用spark-submit将jar提交到spark,是较为常见的做法.但是在开发期间, ...
 - 用gojs写的流程图demo
			
领导要求,可以展开收缩子级,但是子级可以有多个父级,一开始用的dagre-d3.js,但是功能不是太全,无意中看到gojs,感觉还不错,所以拿来改了改... 代码地址:https://github.c ...
 - LeetCode(77):组合
			
Medium! 题目描述: 给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合. 示例: 输入: n = 4, k = 2 输出: [ [2,4], [3,4], [2,3] ...
 - python(8):面向对象编程
			
有三种程序类型: (1)面向过程:按照一定的逻辑顺序,一步步垒代码 (2)面向函数:对用常用的计算,建立函数避免重复 (3)面向对象: 函数的集合,对函数进行分类和封装 (一) 抽象 抽象: 哈巴狗, ...
 - python(3):文件操作/os库
			
文件基本操作 r,以读模式打开, r+=r+w, w, 写模式(清空原来的内容), w+=w+r, a , 追加模式, a+=a+r, rb, wb, ab, b表示以二进制文件打开 想在一段文 ...
 - easyUI-layout布局
			
https://www.cnblogs.com/kexb/p/3685913.html <!DOCTYPE html><html><head> <meta c ...
 - 论文阅读笔记十四:Decoupled Deep Neural Network for Semi-supervised Semantic Segmentation(CVPR2015)
			
论文链接:https://arxiv.org/abs/1506.04924 摘要 该文提出了基于混合标签的半监督分割网络.与当前基于区域分类的单任务的分割方法不同,Decoupled 网络将分割与分类 ...