HDU 4421 Bit Magic(2-sat)
HDU 4421 Bit Magic
pid=4421" target="_blank" style="">题目链接
题意:就依据题目,给定b数组。看能不能构造出一个符合的a数组
思路:把每一个数字的每一个二进制位单独考虑。就变成一个2-sat题目了,依据题目中的式子建立2-sat的边。然后每一位跑2-sat。假设每位都符合。就是YES,假设有一位不符合就是NO
代码:
- #include <cstdio>
- #include <cstring>
- #include <cstdlib>
- #include <vector>
- #include <algorithm>
- using namespace std;
- const int MAXNODE = 505;
- struct TwoSet {
- int n;
- vector<int> g[MAXNODE * 2];
- bool mark[MAXNODE * 2];
- int S[MAXNODE * 2], sn;
- void init(int tot) {
- n = tot * 2;
- for (int i = 0; i < n; i += 2) {
- g[i].clear();
- g[i^1].clear();
- }
- memset(mark, false, sizeof(mark));
- }
- void add_Edge(int u, int uval, int v, int vval) {
- u = u * 2 + uval;
- v = v * 2 + vval;
- g[u^1].push_back(v);
- g[v^1].push_back(u);
- }
- void delete_Edge(int u, int uval, int v, int vval) {
- u = u * 2 + uval;
- v = v * 2 + vval;
- g[u^1].pop_back();
- g[v^1].pop_back();
- }
- bool dfs(int u) {
- if (mark[u^1]) return false;
- if (mark[u]) return true;
- mark[u] = true;
- S[sn++] = u;
- for (int i = 0; i < g[u].size(); i++) {
- int v = g[u][i];
- if (!dfs(v)) return false;
- }
- return true;
- }
- bool solve() {
- for (int i = 0; i < n; i += 2) {
- if (!mark[i] && !mark[i + 1]) {
- sn = 0;
- if (!dfs(i)){
- for (int j = 0; j < sn; j++)
- mark[S[j]] = false;
- sn = 0;
- if (!dfs(i + 1)) return false;
- }
- }
- }
- return true;
- }
- } gao;
- const int N = 505;
- int n, b[N][N];
- bool solve() {
- for (int k = 0; k < 31; k++) {
- gao.init(n);
- for (int i = 0; i < n; i++)
- for (int j = 0; j < n; j++) {
- int tmp = (b[i][j]>>k)&1;
- if (i == j) {
- if (tmp) return false;
- }
- else if (i % 2 == 1 && j % 2 == 1) {
- if (tmp) gao.add_Edge(i, tmp, j, tmp);
- else {
- gao.add_Edge(i, tmp, i, tmp);
- gao.add_Edge(j, tmp, j, tmp);
- }
- }
- else if (i % 2 == 0 && j % 2 == 0) {
- if (tmp) {
- gao.add_Edge(i, tmp, i, tmp);
- gao.add_Edge(j, tmp, j, tmp);
- } else gao.add_Edge(i, tmp, j, tmp);
- } else {
- if (tmp) {
- gao.add_Edge(i, tmp, j, tmp);
- gao.add_Edge(i, !tmp, j, !tmp);
- } else {
- gao.add_Edge(i, tmp, j, !tmp);
- gao.add_Edge(i, !tmp, j, tmp);
- }
- }
- }
- if (!gao.solve()) return false;
- }
- return true;
- }
- int main() {
- while (~scanf("%d", &n)) {
- for (int i = 0; i < n; i++)
- for (int j = 0; j < n; j++)
- scanf("%d", &b[i][j]);
- printf("%s\n", solve() ? "YES" : "NO");
- }
- return 0;
- }
HDU 4421 Bit Magic(2-sat)的更多相关文章
- HDU 4421 Bit Magic (图论-2SAT)
Bit Magic Problem Description Yesterday, my teacher taught me about bit operators: and (&), or ( ...
- 图论(2-sat):HDU 4421 Bit Magic
Bit Magic Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- HDU 4421 Bit Magic(奇葩式解法)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4421 题目大意: 给了你一段代码, 用一个数组的数 对其进行那段代码的处理,是可以得到一个矩阵 让你判 ...
- hdu 4421 Bit Magic
[题意] 这个函数是给A求B的,现在给你B,问你是否能有A的解存在. [2-SAT解法] 对于每个A[i]的每一位运行2-sat算法,只要跑到强连通就可以结束,应为只要判断是否有解,后面拓扑求解就不需 ...
- HDU 5938 Four Operations(四则运算)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- HDU 5775 Bubble Sort(冒泡排序)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- HDU 1711 Number Sequence(数列)
HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- HDU 1005 Number Sequence(数列)
HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...
- hdu 3183 A Magic Lamp(RMQ)
题目链接:hdu 3183 A Magic Lamp 题目大意:给定一个字符串,然后最多删除K个.使得剩下的组成的数值最小. 解题思路:问题等价与取N-M个数.每次取的时候保证后面能取的个数足够,而且 ...
随机推荐
- cvCalcOpticalFlowPyrLK的使用--基于高斯金字塔的稀疏光流特征集求解
void cvCalcOpticalFlowPyrLK( const CvArr* prev, const CvArr* curr, CvArr* prev_pyr, CvArr* curr_pyr, ...
- Problem D: 乌龟棋【四维dp】
Problem D: 乌龟棋 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 24 Solved: 15[Submit][Status][Web Boa ...
- Maven学习笔记3
好了,按照笔记2的方法我们创建好一个web项目(使用maven:java项目还是java项目,web项目还是web项目,唯一的变化既是我们在pom.xml中配置了我们本应该先下载然后导入的jar包,这 ...
- RabbitMQ使用介绍(python)
在我们的项目开发过程中,我们有时会有时候有两个或者多个程序交互的情况,当然就会使用到这里的消息队列来实现.现在比较火的就是RabbitMQ,还有一些ZeroMQ ,ActiveMQ 等等,著名的ope ...
- 9.1(java学习笔记)正则表达式
一.正则表达式 1.1正则表达式 正则表达式是描述一种规则,通过这个规则可以匹配到一类字符串. 2.1正则语法 2.1.1普通字符:字母.数字.下划线.汉字以及没有特殊意义的符号都是普通字符. 正则表 ...
- 【R笔记】R的内存管理和垃圾清理
笔记: 1.R输入命令时速度不要太快,终究是个统计软件,不是编程! 2.memory.limit()查看当前操作系统分配内存给R的最大限度(单位是M?) 3.要经常 rm(object) 或者 rm( ...
- Java高级架构师(一)第19节:X-gen生成相应的Visitor
package cn.javass.themes.smvcsm.visitors; import cn.javass.xgen.genconf.vo.ExtendConfModel; import c ...
- Java高级架构师(一)第13节:Spring MVC实现Web层开发
package com.sishuok.architecture1.customermgr.web; import org.springframework.beans.factory.annotati ...
- iOS中用json接收图片的二进制流
标题可能说的有点混乱,再好好描述一下我遇到的问题: 我负责做一款App的iOS版本,服务器和Android版本都开发完了.服务器的图片存的不是路径,而是在数据库中的blob流对象,由于要求所有数据都用 ...
- ListView控件(上)数据适配器:ListView绑定监听是SetOnItemClickListener
(一) 1.效果图: 2.MainActivity.java package com.example.app5; import android.support.v7.app.AppCompatActi ...