poj 1733
这题离散化+并查集,没看出关dp什么事。(那他为什么放到dp里面)
用Si记录前i项的和。拆成两个点,i*2表示与第i个相同,i*2+1表示与第i个不同。用并查集判断。区间[a,b]就可以看成Sb-S(a-1),用并查集保存S的奇偶性的相同和相异情况。
注意数组开时要开成4*n+4,我在这里RE了一次
代码:
#include<cstdio>
#include<cstdlib>
#include<algorithm>
using namespace std;
struct dt{
int id,p,l;
}a[10100];
int fa[20100];
bool d[5100],f;
bool cmp1(dt x,dt y){
return x.p<y.p;
}
bool cmp2(dt x,dt y){
return x.id<y.id;
}
int find(int x){
return(fa[x]==x)?x:fa[x]=find(fa[x]);
}
void uni(int x,int y){
int m1=find(x),n1=find(y);
// for(int i=0;i<20;i++)printf("%d ",fa[i]);printf("\n");
// printf("%d %d\n",m1,n1);
if(abs(m1-n1)==1 && (m1+n1)%4==1){
f=1;
return;
}
fa[n1]=m1;
return;
}
int main(){
int n;
scanf("%d",&n);
scanf("%d",&n);
for(int i=0;i<n*4+4;i++)
fa[i]=i;
for(int i=0;i<n;i++){
int x,y;
char ch[20];
scanf("%d%d%s",&x,&y,ch);
a[i*2].id=i*2,a[i*2].p=x-1;
a[i*2+1].id=i*2+1,a[i*2+1].p=y-1;
if(ch[0]=='e')d[i]=0;else d[i]=1;
}
sort(a,a+n*2,cmp1);
a[0].l=1;
for(int i=1;i<n*2;i++)
if(a[i].p==a[i-1].p)
a[i].l=a[i-1].l;
else a[i].l=a[i-1].l+1;
sort(a,a+n*2,cmp2);
f=0;int ans=0;
for(int i=0;i<n;i++){
int p=a[i*2].l-1,q=a[i*2+1].l;
// printf("%d %d\n",p,q);
if(d[i]){
uni(p*2,q*2+1);
if(f)break;
uni(p*2+1,q*2);
if(f)break;
}else{
uni(p*2,q*2);
if(f)break;
uni(p*2+1,q*2+1);
if(f)break;
}
ans++;
}
printf("%d\n",ans);
return 0;
}
poj 1733的更多相关文章
- 类似区间计数的种类并查集两题--HDU 3038 & POJ 1733
1.POJ 1733 Parity game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5744 Accepted: ...
- poj 1733 并查集+hashmap
题意:题目:有一个长度 已知的01串,给出多个条件,[l,r]这个区间中1的个数是奇数还是偶数,问前几个是正确的,没有矛盾 链接:点我 解题思路:hash离散化+并查集 首先我们不考虑离散化:s[x] ...
- poj 1733(带权并查集+离散化)
题目链接:http://poj.org/problem?id=1733 思路:这题一看就想到要用并查集做了,不过一看数据这么大,感觉有点棘手,其实,我们仔细一想可以发现,我们需要记录的是出现过的节点到 ...
- poj 1733 Parity game(带权并查集+离散化)
题目链接:http://poj.org/problem?id=1733 题目大意:有一个很长很长含有01的字符串,长度可达1000000000,首先告诉你字符串的长度n,再给一个m,表示给你m条信息, ...
- POJ 1733 Parity game(种类并查集)
http://poj.org/problem?id=1733 题意: 给出一个01串,有多次询问,每次回答[l,r]这个区间内1的个数的奇偶性,但是其中有一些回答是错误的,问到第几个回答时与前面的回答 ...
- (并查集 建立关系)Parity game -- POJ -1733
链接: http://poj.org/problem?id=1733 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=82830#probl ...
- POJ 1733 Parity game(带权并查集)
题目链接:http://poj.org/problem?id=1733 题目大意:给你m条信息,每条信息告诉你区间l~r的1的个数是奇数还是偶数,如果后面出现信息跟前面矛盾则这条信息是错误的,问在第一 ...
- 【POJ 1733】 Parity Game
[题目链接] http://poj.org/problem?id=1 [算法] 并查集 [代码] #include <algorithm> #include <bitset> ...
- POJ 1733 Parity game (并查集)
Parity game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6816 Accepted: 2636 Descr ...
随机推荐
- AJAX提交方法(GET)Demon
AJAX作为一种异步的Javascript程序执行方法,极大的弥补了HTTP协议的不足(HTTP协议为无状态协议),可以无需加载整个页面,只需加载所需数据即可,浏览器内置的XMLHttp对象有open ...
- ASP.NET MVC的运行机制--url的全局分析
全局 首先我们来看一副图片 首先,用户通过Web浏览器向服务器发送一条url请求,这里请求的url不再是xxx.aspx格式,而是http://HostName/ControllerNam ...
- 有利于SEO的DIV+CSS的命名规则
搜索引擎优化(seo)有很多工作要做,其中对代码的优化是一个很关键的步骤.为了更加符合SEO的规范,下面是目前流行的CSS+DIV的命名规则: 页头:header登录条:loginBar标志:logo ...
- image的加载事件(onload)和加载状态(complete)
之前做过这样一个需求,要让商家页的商家图片按照图片外面box的大小等比例缩放.之前的想法是在页面中先输出图片的src,然后在页面底部初始化js,然后在js中写相应的可以使图片按照box的大小等比例缩放 ...
- 【腾讯GAD暑期训练营游戏程序班】游戏中的特效系统作业说明文档
- 容器化redis高可用方案
偶然看到一个GITHUB项目,提供了一套Docker Compose下的redis Sentinel方案. 项目地址https://github.com/AliyunContainerService/ ...
- 通过接口实现JAVA和.NET互调用-JNInterface
使用C#编程多年,也十分感激微软在语言架构.语法糖.编辑器等方面给自己带来的便利.但因为最近工作中有接触到JAVA,渐渐地发现的确像大家说的那样,JAVA的生态很好,要找点什么几乎都有现成的,于是自然 ...
- C#程序员的春天之从零开始学习unity3D游戏开发入门教程二(创建项目及基本面板介绍)
一项目创建: 创建项目是开发的第一步. 运行untiy之后如果是第一次运行会弹出 我们这里随便创建一个项目. 二Untiy面板介绍: 三代码编辑器的切换: 这里我安装了vs2012. 到这里开发环境基 ...
- [Django 1]安装Django并创建虚拟虚拟环境项目
1)安装Django 使用pip来安装,命令如下: pip3 install Djangopip install Django(安装到python2)python3 -m pip install Dj ...
- cosbench 异常 FreeMarker template error: The following has evaluated to null or missing
问题现象: 使用Cosbench 0.4.2.c4 版本测试Ceph RGW read test失败,遇到异常如下: FreeMarker template error: The following ...