HDU 4421 Bit Magic

pid=4421" target="_blank" style="">题目链接

题意:就依据题目,给定b数组。看能不能构造出一个符合的a数组

思路:把每一个数字的每一个二进制位单独考虑。就变成一个2-sat题目了,依据题目中的式子建立2-sat的边。然后每一位跑2-sat。假设每位都符合。就是YES,假设有一位不符合就是NO

代码:

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <cstdlib>
  4. #include <vector>
  5. #include <algorithm>
  6. using namespace std;
  7.  
  8. const int MAXNODE = 505;
  9.  
  10. struct TwoSet {
  11. int n;
  12. vector<int> g[MAXNODE * 2];
  13. bool mark[MAXNODE * 2];
  14. int S[MAXNODE * 2], sn;
  15.  
  16. void init(int tot) {
  17. n = tot * 2;
  18. for (int i = 0; i < n; i += 2) {
  19. g[i].clear();
  20. g[i^1].clear();
  21. }
  22. memset(mark, false, sizeof(mark));
  23. }
  24.  
  25. void add_Edge(int u, int uval, int v, int vval) {
  26. u = u * 2 + uval;
  27. v = v * 2 + vval;
  28. g[u^1].push_back(v);
  29. g[v^1].push_back(u);
  30. }
  31.  
  32. void delete_Edge(int u, int uval, int v, int vval) {
  33. u = u * 2 + uval;
  34. v = v * 2 + vval;
  35. g[u^1].pop_back();
  36. g[v^1].pop_back();
  37. }
  38.  
  39. bool dfs(int u) {
  40. if (mark[u^1]) return false;
  41. if (mark[u]) return true;
  42. mark[u] = true;
  43. S[sn++] = u;
  44. for (int i = 0; i < g[u].size(); i++) {
  45. int v = g[u][i];
  46. if (!dfs(v)) return false;
  47. }
  48. return true;
  49. }
  50.  
  51. bool solve() {
  52. for (int i = 0; i < n; i += 2) {
  53. if (!mark[i] && !mark[i + 1]) {
  54. sn = 0;
  55. if (!dfs(i)){
  56. for (int j = 0; j < sn; j++)
  57. mark[S[j]] = false;
  58. sn = 0;
  59. if (!dfs(i + 1)) return false;
  60. }
  61. }
  62. }
  63. return true;
  64. }
  65. } gao;
  66.  
  67. const int N = 505;
  68. int n, b[N][N];
  69.  
  70. bool solve() {
  71. for (int k = 0; k < 31; k++) {
  72. gao.init(n);
  73. for (int i = 0; i < n; i++)
  74. for (int j = 0; j < n; j++) {
  75. int tmp = (b[i][j]>>k)&1;
  76. if (i == j) {
  77. if (tmp) return false;
  78. }
  79. else if (i % 2 == 1 && j % 2 == 1) {
  80. if (tmp) gao.add_Edge(i, tmp, j, tmp);
  81. else {
  82. gao.add_Edge(i, tmp, i, tmp);
  83. gao.add_Edge(j, tmp, j, tmp);
  84. }
  85. }
  86. else if (i % 2 == 0 && j % 2 == 0) {
  87. if (tmp) {
  88. gao.add_Edge(i, tmp, i, tmp);
  89. gao.add_Edge(j, tmp, j, tmp);
  90. } else gao.add_Edge(i, tmp, j, tmp);
  91. } else {
  92. if (tmp) {
  93. gao.add_Edge(i, tmp, j, tmp);
  94. gao.add_Edge(i, !tmp, j, !tmp);
  95. } else {
  96. gao.add_Edge(i, tmp, j, !tmp);
  97. gao.add_Edge(i, !tmp, j, tmp);
  98. }
  99. }
  100. }
  101. if (!gao.solve()) return false;
  102. }
  103. return true;
  104. }
  105.  
  106. int main() {
  107. while (~scanf("%d", &n)) {
  108. for (int i = 0; i < n; i++)
  109. for (int j = 0; j < n; j++)
  110. scanf("%d", &b[i][j]);
  111. printf("%s\n", solve() ? "YES" : "NO");
  112. }
  113. return 0;
  114. }

HDU 4421 Bit Magic(2-sat)的更多相关文章

  1. HDU 4421 Bit Magic (图论-2SAT)

    Bit Magic Problem Description Yesterday, my teacher taught me about bit operators: and (&), or ( ...

  2. 图论(2-sat):HDU 4421 Bit Magic

    Bit Magic Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  3. HDU 4421 Bit Magic(奇葩式解法)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4421 题目大意: 给了你一段代码, 用一个数组的数 对其进行那段代码的处理,是可以得到一个矩阵 让你判 ...

  4. hdu 4421 Bit Magic

    [题意] 这个函数是给A求B的,现在给你B,问你是否能有A的解存在. [2-SAT解法] 对于每个A[i]的每一位运行2-sat算法,只要跑到强连通就可以结束,应为只要判断是否有解,后面拓扑求解就不需 ...

  5. HDU 5938 Four Operations(四则运算)

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  6. HDU 5775 Bubble Sort(冒泡排序)

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  7. HDU 1711 Number Sequence(数列)

    HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...

  8. HDU 1005 Number Sequence(数列)

    HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...

  9. hdu 3183 A Magic Lamp(RMQ)

    题目链接:hdu 3183 A Magic Lamp 题目大意:给定一个字符串,然后最多删除K个.使得剩下的组成的数值最小. 解题思路:问题等价与取N-M个数.每次取的时候保证后面能取的个数足够,而且 ...

随机推荐

  1. cvCalcOpticalFlowPyrLK的使用--基于高斯金字塔的稀疏光流特征集求解

    void cvCalcOpticalFlowPyrLK( const CvArr* prev, const CvArr* curr, CvArr* prev_pyr, CvArr* curr_pyr, ...

  2. Problem D: 乌龟棋【四维dp】

    Problem D: 乌龟棋 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 24  Solved: 15[Submit][Status][Web Boa ...

  3. Maven学习笔记3

    好了,按照笔记2的方法我们创建好一个web项目(使用maven:java项目还是java项目,web项目还是web项目,唯一的变化既是我们在pom.xml中配置了我们本应该先下载然后导入的jar包,这 ...

  4. RabbitMQ使用介绍(python)

    在我们的项目开发过程中,我们有时会有时候有两个或者多个程序交互的情况,当然就会使用到这里的消息队列来实现.现在比较火的就是RabbitMQ,还有一些ZeroMQ ,ActiveMQ 等等,著名的ope ...

  5. 9.1(java学习笔记)正则表达式

    一.正则表达式 1.1正则表达式 正则表达式是描述一种规则,通过这个规则可以匹配到一类字符串. 2.1正则语法 2.1.1普通字符:字母.数字.下划线.汉字以及没有特殊意义的符号都是普通字符. 正则表 ...

  6. 【R笔记】R的内存管理和垃圾清理

    笔记: 1.R输入命令时速度不要太快,终究是个统计软件,不是编程! 2.memory.limit()查看当前操作系统分配内存给R的最大限度(单位是M?) 3.要经常 rm(object) 或者 rm( ...

  7. Java高级架构师(一)第19节:X-gen生成相应的Visitor

    package cn.javass.themes.smvcsm.visitors; import cn.javass.xgen.genconf.vo.ExtendConfModel; import c ...

  8. Java高级架构师(一)第13节:Spring MVC实现Web层开发

    package com.sishuok.architecture1.customermgr.web; import org.springframework.beans.factory.annotati ...

  9. iOS中用json接收图片的二进制流

    标题可能说的有点混乱,再好好描述一下我遇到的问题: 我负责做一款App的iOS版本,服务器和Android版本都开发完了.服务器的图片存的不是路径,而是在数据库中的blob流对象,由于要求所有数据都用 ...

  10. ListView控件(上)数据适配器:ListView绑定监听是SetOnItemClickListener

    (一) 1.效果图: 2.MainActivity.java package com.example.app5; import android.support.v7.app.AppCompatActi ...