题目链接:http://poj.org/problem?id=3678

  分别对and,or,xor推出相对应的逻辑关系:

    逻辑关系      1              0

     A and B     A'->A,B'->B          A->B',B->A'

     A or B   A'->B',B'->A          A->A',B->B'

     A xor B     A'->B,B'->A,A->B',B->A'      A->B,A'->B'

  1. //STATUS:C++_AC_96MS_472KB
  2. #include <functional>
  3. #include <algorithm>
  4. #include <iostream>
  5. //#include <ext/rope>
  6. #include <fstream>
  7. #include <sstream>
  8. #include <iomanip>
  9. #include <numeric>
  10. #include <cstring>
  11. #include <cassert>
  12. #include <cstdio>
  13. #include <string>
  14. #include <vector>
  15. #include <bitset>
  16. #include <queue>
  17. #include <stack>
  18. #include <cmath>
  19. #include <ctime>
  20. #include <list>
  21. #include <set>
  22. #include <map>
  23. using namespace std;
  24. //using namespace __gnu_cxx;
  25. //define
  26. #define pii pair<int,int>
  27. #define mem(a,b) memset(a,b,sizeof(a))
  28. #define lson l,mid,rt<<1
  29. #define rson mid+1,r,rt<<1|1
  30. #define PI acos(-1.0)
  31. //typedef
  32. typedef long long LL;
  33. typedef unsigned long long ULL;
  34. //const
  35. const int N=;
  36. const int INF=0x3f3f3f3f;
  37. const int MOD=,STA=;
  38. const LL LNF=1LL<<;
  39. const double EPS=1e-;
  40. const double OO=1e15;
  41. const int dx[]={-,,,};
  42. const int dy[]={,,,-};
  43. const int day[]={,,,,,,,,,,,,};
  44. //Daily Use ...
  45. inline int sign(double x){return (x>EPS)-(x<-EPS);}
  46. template<class T> T gcd(T a,T b){return b?gcd(b,a%b):a;}
  47. template<class T> T lcm(T a,T b){return a/gcd(a,b)*b;}
  48. template<class T> inline T lcm(T a,T b,T d){return a/d*b;}
  49. template<class T> inline T Min(T a,T b){return a<b?a:b;}
  50. template<class T> inline T Max(T a,T b){return a>b?a:b;}
  51. template<class T> inline T Min(T a,T b,T c){return min(min(a, b),c);}
  52. template<class T> inline T Max(T a,T b,T c){return max(max(a, b),c);}
  53. template<class T> inline T Min(T a,T b,T c,T d){return min(min(a, b),min(c,d));}
  54. template<class T> inline T Max(T a,T b,T c,T d){return max(max(a, b),max(c,d));}
  55. //End
  56.  
  57. int first[N*],next[N*N*],vis[N*],S[N*];
  58. int n,m,mt,cnt;
  59.  
  60. struct Edge{
  61. int u,v;
  62. }e[N*N*];
  63.  
  64. void adde(int a,int b)
  65. {
  66. e[mt].u=a,e[mt].v=b;
  67. next[mt]=first[a];first[a]=mt++;
  68. }
  69.  
  70. int dfs(int u)
  71. {
  72. if(vis[u^])return ;
  73. if(vis[u])return ;
  74. int i;
  75. vis[u]=;
  76. S[cnt++]=u;
  77. for(i=first[u];i!=-;i=next[i]){
  78. if(!dfs(e[i].v))return ;
  79. }
  80. return ;
  81. }
  82.  
  83. int Twosat()
  84. {
  85. int i,j;
  86. mem(vis,);
  87. for(i=;i<n;i+=){
  88. if(vis[i] || vis[i^])continue;
  89. cnt=;
  90. if(!dfs(i)){
  91. while(cnt)vis[S[--cnt]]=;
  92. if(!dfs(i^))return ;
  93. }
  94. }
  95. return ;
  96. }
  97.  
  98. int main()
  99. {
  100. // freopen("in.txt","r",stdin);
  101. int i,j,a,b,c;
  102. char op[];
  103. while(~scanf("%d%d",&n,&m) && (n||m))
  104. {
  105. n<<=;
  106. mem(first,-);mt=;
  107. while(m--){
  108. scanf("%d%d%d%s",&a,&b,&c,op);
  109. a<<=,b<<=;
  110. if(op[]=='A'){
  111. if(c){
  112. adde(a^,a);
  113. adde(b^,a);
  114. }
  115. else {
  116. adde(a,b^);
  117. adde(b,a^);
  118. }
  119. }
  120. else if(op[]=='O'){
  121. if(c){
  122. adde(a^,b);
  123. adde(b^,a);
  124. }
  125. else {
  126. adde(a,a^);
  127. adde(b,b^);
  128. }
  129. }
  130. else {
  131. if(c){
  132. adde(a^,b);
  133. adde(b^,a);
  134. adde(a,b^);
  135. adde(b,a^);
  136. }
  137. else {
  138. adde(a,b);
  139. adde(a^,b^);
  140. }
  141. }
  142. }
  143.  
  144. printf("%s\n",Twosat()?"YES":"NO");
  145. }
  146. return ;
  147. }

POJ-3678 Katu Puzzle 2sat的更多相关文章

  1. poj 3678 Katu Puzzle(2-sat)

    Description Katu Puzzle ≤ c ≤ ). One Katu ≤ Xi ≤ ) such that for each edge e(a, b) labeled by op and ...

  2. poj 3678 Katu Puzzle 2-SAT 建图入门

    Description Katu Puzzle is presented as a directed graph G(V, E) with each edge e(a, b) labeled by a ...

  3. POJ 3678 Katu Puzzle 2-SAT 强连通分量 tarjan

    http://poj.org/problem?id=3678 给m条连接两个点的边,每条边有一个权值0或1,有一个运算方式and.or或xor,要求和这条边相连的两个点经过边上的运算后的结果是边的权值 ...

  4. POJ 3678 Katu Puzzle(2-SAT,合取范式大集合)

    Katu Puzzle Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9987   Accepted: 3741 Descr ...

  5. POJ 3678 Katu Puzzle (经典2-Sat)

    Katu Puzzle Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6553   Accepted: 2401 Descr ...

  6. POJ 3678 Katu Puzzle (2-SAT)

                                                                         Katu Puzzle Time Limit: 1000MS ...

  7. POJ 3678 Katu Puzzle(2 - SAT) - from lanshui_Yang

    Description Katu Puzzle is presented as a directed graph G(V, E) with each edge e(a, b) labeled by a ...

  8. POJ 3678 Katu Puzzle (2-SAT,常规)

    题意:给出n个点,每个点上有一个数字可以0或1,然后给出m条限制,要求a和b两个点上的数字满足 a op b = c,op和c都是给定.问是否能够有一组解满足所有限制?(即点上的数字是0是1由你决定) ...

  9. poj 3678 Katu Puzzle(Two Sat)

    题目链接:http://poj.org/problem?id=3678 代码: #include<cstdio> #include<cstring> #include<i ...

  10. POJ 3678 Katu Puzzle

    Description 给出一个关系,包括 And,Xor,Or 问是否存在解. Sol 经典的2-SAT问题. 把每个值看成两个点,一个点代表选 \(0\) ,另一个代表选 \(1\) . 首先来看 ...

随机推荐

  1. 使用pdb调试python

    python pdb调试 python -m pdb myscript.py #注意这会重启myscript.py,这样启动的话,代码每一行都是一个节点 也可以在程序中这么设置断点: import p ...

  2. 2014年度辛星css教程夏季版第四节

    接下来的这一节我计划讲解的是超链接和列表的样式,然后我们做出一个导航栏出来,其实导航栏是非常常见的,但是我们这里做得这个有点并不那么完善,等我们学完了css之后再完善它. ************** ...

  3. Linux下STM32开发环境的搭建

    目录 一.概述 1.目的 2.开发环境描述 3.Eclipse构建的STM32集成开发环境结构 4.GDB / GDB Server 调试模型 二.搭建步骤 三.详细的搭建过程 1.安装eclipse ...

  4. 开发设计模式(五)单例模式(Singleton Pattern)

    http://blog.sina.com.cn/s/blog_89d90b7c0101805m.html 单例模式:意思就是只有一个实例.单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提 ...

  5. iOS 日历类(NSCalendar)

    对于时间的操作在开发中很常见,但有时候我们需要获取到一年后的时间,或者一周后的时间.靠通过秒数计算是不行的.那就牵扯到另外一个日历类(NSCalendar).下面先简单看一下 NSDate let d ...

  6. iOS 8 定位失败问题

    首先plist定义两个string:  NSLocationWhenInUseUsageDescription NSLocationAlwaysUsageDescription 然后调用 [self. ...

  7. mongodb MongoDB 聚合 group

    MongoDB 聚合 MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*). 基本语法为:db.col ...

  8. A Neural Network in 11 lines of Python

    A Neural Network in 11 lines of Python A bare bones neural network implementation to describe the in ...

  9. jsp include包含html页面产生的乱码问题

    大家都知道在jsp中include的有两种方式,一种是<jsp:include page="">,另一种是<%@ include file="" ...

  10. 132. Palindrome Partitioning II

    题目: Given a string s, partition s such that every substring of the partition is a palindrome. Return ...