博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1733 Parity game
阅读量:6693 次
发布时间:2019-06-25

本文共 2486 字,大约阅读时间需要 8 分钟。

题意:对一个只由1和0组成的字符串,给出指令,a b even/odd,表示字符串中第a位到第b位之间的1的个数为even/odd(偶数/奇数)。给出m个指令,a,b <= 10^9,问第一个与前面指令矛盾的指令是哪一个,如果没有与前面矛盾的指令,就输出m。若m为0,则输出m。

解法:类似POJ 1182。首先设函数g(x)表示字符串的前x位含有1的个数,令g(0) = 0。则指令a b even/odd的信息转化为g(a-1)和g(b)的奇偶性是否相同。所以,建一个树,每个节点有两个参数,参数f表示其父亲节点的编号,参数r表示它与父亲节点的奇偶性是否相同。(0表示相同,1表示不同)。

   由于题目数据太大,a,b <= 10^9,但是m <= 5000,所以要离散化处理。

tag:并查集

1 /*  2  * Author:  Plumrain  3  * Created Time:  2013-11-27 17:53  4  * File Name: DS-POJ-1733.cpp  5  */  6 #include 
7 #include
8 #include
9 #include
10 #include
11 12 using namespace std; 13 14 #define PB push_back 15 16 struct temp{ 17 int a, b; 18 bool x; 19 char s[10]; 20 }; 21 22 struct node{ 23 int f, r; 24 }; 25 26 int n, m, all; 27 vector
ttt; 28 map
mp; 29 node a[10005]; 30 temp tt[5005]; 31 32 void init() 33 { 34 mp.clear(); 35 ttt.clear(); 36 37 scanf ("%d", &m); 38 39 if (!m) 40 return; 41 42 for (int i = 0; i < m; ++ i){ 43 scanf ("%d%d%s", &tt[i].a, &tt[i].b, tt[i].s); 44 45 if (tt[i].a > tt[i].b) 46 swap(tt[i].a, tt[i].b); 47 48 -- tt[i].a; 49 if (tt[i].s[0] == 'e') tt[i].x = 0; 50 else tt[i].x = 1; 51 ttt.PB (tt[i].a); ttt.PB (tt[i].b); 52 } 53 54 sort(ttt.begin(), ttt.end()); 55 int tmp = ttt[0], sz = ttt.size(); 56 all = 0; 57 mp[tmp] = all++; 58 for (int i = 1; i < sz; ++ i) if (ttt[i] != tmp){ 59 tmp = ttt[i]; 60 mp[tmp] = all++; 61 } 62 63 for (int i = 0; i < all; ++ i){ 64 a[i].f = i; 65 a[i].r = 0; 66 } 67 } 68 69 int find(int x) 70 { 71 if (x != a[x].f){ 72 int y = a[x].f; 73 a[x].f = find(a[x].f); 74 a[x].r = (a[x].r + a[y].r) % 2; 75 } 76 return a[x].f; 77 } 78 79 void merge(int ta, int tb, bool x, int fa, int fb) 80 { 81 a[fb].f = fa; 82 a[fb].r = (a[ta].r + a[tb].r + x) % 2; 83 } 84 85 bool ok(int ta, int tb, bool x, int fa, int fb) 86 { 87 return x == ((a[ta].r + a[tb].r) % 2); 88 } 89 90 int gao() 91 { 92 bool x; 93 int ta, tb, fa, fb; 94 for (int i = 0; i < m; ++ i){ 95 ta = mp[tt[i].a]; tb = mp[tt[i].b]; x = tt[i].x; 96 fa = find(ta); fb = find(tb); 97 98 if (fa != fb) 99 merge(ta, tb, x, fa, fb);100 else101 if (!ok(ta, tb, x, fa, fb)) return i;102 }103 return m;104 }105 106 int main()107 {108 int n;109 while (scanf ("%d", &n) != EOF){110 init();111 if (!m) printf ("0\n");112 else printf ("%d\n", gao());113 }114 return 0;115 }
View Code

 

 

转载于:https://www.cnblogs.com/plumrain/p/POJ_1733.html

你可能感兴趣的文章
SCOM 2012知识分享-20:管理用户角色
查看>>
DPM2012R2-case:无法枚举受保护的计算机上的一个或多个共享
查看>>
《从零开始学Swift》学习笔记(Day 30)——选择类还是结构体呢?
查看>>
LaTeXila:Linux 的多语言 LaTeX 编辑器简介
查看>>
恭喜CocoStudio 1.5和Mac版本发布
查看>>
Chrome的JS调试工具
查看>>
OnClientClick和OnClick同时使用!
查看>>
把时间转成适合符合日常习惯的格式【js】
查看>>
c 数组
查看>>
Kafka 跨集群同步方案(转)
查看>>
LEA指令
查看>>
Delphi MaskEdit用法(转)
查看>>
极客Web开发资源大荟萃
查看>>
求数组的最大子数组值和最长公共子序列问题
查看>>
surfaceDestroyed什么时候被调用
查看>>
儿时不竞争,长大才胜出(转)
查看>>
Protobuf从安装到配置整理帖
查看>>
Java抓取网页数据(原网页+Javascript返回数据)
查看>>
MYSQL 的 6 个返回时间日期函数
查看>>
银行综合储蓄业务系统,水平为学了一年C语言
查看>>