题意

根据图中公式由A[]构造B[][],现在给你B,问你存不存在一个数组A使之成立。

题解:对于每一位进行2-sat求解。

比赛半个小时时间,没做出来……

一直T。

因为本身对算法不确定,所以也不知道怎么办

赛后才发现是数组开小了、、、、

真坑啊。。。

#include <bits/stdc++.h>

using namespace std;

const int N = ;
int a[N], b[N][N]; struct Edge {
int from, to, next;
} edge[N*N*];
int head[N], cntE; void addedge(int u, int v) {
edge[cntE].from = u;
edge[cntE].to = v;
edge[cntE].next = head[u];
head[u] = cntE++;
} int dfn[N], low[N], idx;
int stk[N], top;
int in[N];
int kind[N], cnt; void tarjan(int u) {
dfn[u] = low[u] = ++idx;
in[u] = true;
stk[++top] = u;
for (int i = head[u]; ~i; i = edge[i].next) {
int v = edge[i].to;
if (!dfn[v]) tarjan(v), low[u] = min(low[u], low[v]);
else if (in[v]) low[u] = min(low[u], dfn[v]);
}
if (low[u] == dfn[u]) {
++cnt;
while () {
int v = stk[top--];
kind[v] = cnt;
in[v] = false;
if (v == u) break;
}
}
} int opp[N], ind[N], col[N];
bool topsort(int n) {
for (int i = ; i < *n; ++i) {
if (!dfn[i]) tarjan(i);
}
for (int i = ; i < n; ++i) {
int k1 = kind[i], k2 = kind[i+n];
if (k1 == k2) return false;
}
return true;
} void init() {
cntE = ;
memset(head, -, sizeof head);
memset(dfn, , sizeof dfn);
memset(in, false, sizeof in);
idx = top = cnt = ;
memset(ind, , sizeof ind);
memset(col, , sizeof col);
} int main()
{
//freopen("in.txt", "r", stdin); int n;
while (~scanf("%d", &n)) {
for (int i = ; i < n; ++i) {
for (int j = ; j < n; ++j) {
scanf("%d", &b[i][j]);
}
} bool fg = true; for (int i = ; i < n; ++i) {
for (int j = i; j < n; ++j) {
if (i == j) {
if (b[i][j] != ) {
fg = false;
break;
}
} else if (b[i][j] != b[j][i]) {
fg = false;
break;
}
}
if (!fg) break;
} if (!fg) {
printf("NO\n");
continue;
} for (int w = ; w <= ; ++w) {
init();
int cnt = ;
for (int i = ; i < n; ++i) {
for (int j = i+; j < n; ++j) {
//if (i == j) continue; if (i % == && j % == ) {
if (b[i][j] & ( << w)) {
addedge(i, i+n);
addedge(j, j+n);
} else {
addedge(j+n, i);
addedge(i+n, j);
}
} else if (i % == && j % == ) {
if (b[i][j] & ( << w)) {
addedge(j, i+n);
addedge(i, j+n);
} else {
addedge(i+n, i);
addedge(j+n, j);
}
} else {
if (b[i][j] & ( << w)) {
addedge(i, j+n);
addedge(j, i+n);
addedge(j+n, i);
addedge(i+n, j);
} else {
addedge(i, j);
addedge(j, i);
addedge(i+n, j+n);
addedge(j+n, i+n);
}
}
}
}
if (!topsort(n)) {
fg = false;
break;
}
} if (fg) printf("YES\n");
else printf("NO\n");
}
return ;
}

hdu4421-Bit Magic(2-SAT)的更多相关文章

  1. 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 ...

  2. 学习笔记(two sat)

    关于two sat算法 两篇很好的论文由对称性解2-SAT问题(伍昱), 赵爽 2-sat解法浅析(pdf). 一些题目的题解 poj 3207 poj 3678 poj 3683 poj 3648 ...

  3. FZU 2280 Magic(字符串Hash)题解

    题意:给你n个字符串,每个字符串有一个值w,有q次询问,一共两种操作:一是“1 x y”表示把第x个串的w变为y:二是“2 x”,输出第x个串能放几次魔法.放魔法的条件是这样:用串x放魔法,如果在1~ ...

  4. 2002-2003 ACM-ICPC Northeastern European Regional Contest (NEERC 02) H Heroes Of Might And Magic (隐含dp)

    问题是求一个方案,实际隐含一个dp.法力是递减的,所以状态是DAG,对于一个确定的状态,我们贪心地希望英雄的血量尽量大. 分析:定义状态dp[i][p][h]表示是已经用了i的法力值,怪兽的位置在p, ...

  5. Katu Puzzle POJ - 3678 (2 - sat)

    有N个变量X1X1~XNXN,每个变量的可能取值为0或1. 给定M个算式,每个算式形如 XaopXb=cXaopXb=c,其中 a,b 是变量编号,c 是数字0或1,op 是 and,or,xor 三 ...

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

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

  7. Math Magic(完全背包)

    Math Magic Time Limit:3000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu Submit Sta ...

  8. CF 1064B Equations of Mathematical Magic(思维规律)

    Description Colossal! — exclaimed Hawk-nose. — A programmer! That's exactly what we are looking for. ...

  9. LA 3211 飞机调度(2—SAT)

    https://vjudge.net/problem/UVALive-3211 题意: 有n架飞机需要着陆,每架飞机都可以选择“早着陆”和“晚着陆”两种方式之一,且必须选择一种,第i架飞机的早着陆时间 ...

  10. 【Beginning Python】抽象(未完)

    [懒惰即是美德] 抽象意味着良好的可读性:说明你在努力做什么,而不是给出你正在如何做的细节. [抽象和结构] 程序应该是非常抽象的,就像“下载网页.计算频率.打印每个单词的频率”一样易懂.翻译成程序就 ...

随机推荐

  1. [ionic开源项目教程] - 第6讲 过滤器filter的使用

    过滤器filter的使用 1.回顾 再熟悉一下tab1.html的代码: <div class="list"> <a ng-repeat="item i ...

  2. 转:整理一下Entity Framework的查询

    Entity Framework是个好东西,虽然没有Hibernate功能强大,但使用更简便.今天整理一下常见SQL如何用EF来表达,Func形式和Linq形式都会列出来(本人更喜欢Func形式). ...

  3. 正则表达式 java版

    众所周知,在程序开发中,难免会遇到需要匹配.查找.替换.判断字符串的情况发生,而这些情况有时又比较复杂,如果用纯编码方式解决,往往会浪费程序员的时间及精力.因此,学习及使用正则表达式,便成了解决这一矛 ...

  4. Centos移除图形界面

    在此之前为了试验SAS Linux,在一台centos服务器上安装了desktop界面, 目前需要删除这些界面组件,可以按照以下步骤实现: 1. yum grouplist查看安装的组件 2. 使用y ...

  5. OpenGL学习之路(一)

    1 引子 虽然是计算机科班出身,但从小对几何方面的东西就不太感冒,空间想象能力也较差,所以从本科到研究生,基本没接触过<计算机图形学>.为什么说基本没学过呢?因为好奇(尤其是惊叹于三维游戏 ...

  6. PHP 截取字符串专题

    1. 截取GB2312中文字符串 < ?php//截取中文字符串function mysubstr($str, $start, $len) {    $tmpstr = "" ...

  7. Linux makefile教程之概述一[转]

    概述—— 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些 Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makef ...

  8. Ajax请求内嵌套Ajax请求的方法

    前段时间做项目,需要把全国省市的两个XML文件整合成一个JSON格式的数据,手写的话觉得数据太多了,而且容易出错,于是就想到了用Ajax嵌套的方法来解决,就想平时用Ajax的方法直接嵌套,都会先读出外 ...

  9. Android Application 深入分析

    http://blog.csdn.net/rain_butterfly/article/details/37598939

  10. Drupal如何更新注册表?

    Drupal的注册表是指registry和registry_file两个数据表.前一个表保存所有可用的类和接口以及它们所对应的文件,后一个表保存每个文件的hash码. 1. 将所有需要更新的文件都汇总 ...