博客
关于我
HDU Bit Magic (2-Sat)
阅读量:323 次
发布时间:2019-03-04

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

  • 题意
    已知一位数组a[]和二维数组b[][]满足以下关系
    如图所示
    给定数组b[][],问是否存在数组a[],如果存在,输出"YES",否则输出"NO"
    • 题解
      写的是2-Sat的专题,想了好久都没想到怎么和2-Sat扯上关系,后来看了题解,说是按位进行2-Sat,就知道要怎么做了。因为位数最多不超过31位i,我一开始想的是从数组b[][]中找到条件,对这31位综合起来只进行一次2-Sat,后来T掉了,但是想了想复杂度是不会T的,现在还想不明白。后来只好对每一位建图,对每一位进行一次2-Sat,如果有一位找出了矛盾,就直接NO了。
    • 代码
#pragma GCC optimize(2)#include
using namespace std;typedef long long ll;typedef unsigned long ul;typedef unsigned long long ull;#define pi acos(-1.0)#define e exp(1.0)#define pb push_back#define mk make_pair#define fir first#define sec second#define scf scanf#define prf printftypedef pair
pa;const int dir_4[4][2]={ -1,0,0,1,1,0,0,-1};const int dir_8[8][2]={ -1,-1,-1,0,-1,1,0,1,1,1,1,0,1,-1,0,-1};const ll INF=0x3f3f3f3f3f3f3f3f;const int MAX_N=520*2;struct node{ int to,nex;}edge[1000000];int N,cnt,tot,scc_cnt,head[MAX_N],dfn[MAX_N],low[MAX_N],sccnum[MAX_N];int base;ll b[520][520];void add(int u,int v){ edge[cnt].to=v; edge[cnt].nex=head[u]; head[u]=cnt++; return ;}stack
st;void Init(){ cnt=tot=scc_cnt=0; for(int i=0;i

转载地址:http://cpph.baihongyu.com/

你可能感兴趣的文章
VUE3(八)setup与ref函数
查看>>
Vue之Element标签页保留用户操作缓存。
查看>>
智能合约开发实践(1)
查看>>
MATLAB——操作矩阵的常用函数
查看>>
CMake自学记录,看完保证你知道CMake怎么玩!!!
查看>>
ORB-SLAM2:LoopClosing线程学习随笔【李哈哈:看看总有收获篇】
查看>>
牛客练习赛56 D 小翔和泰拉瑞亚(线段树)
查看>>
Codeforces Round #614 (Div. 2) B - JOE is on TV! (简单贪心)
查看>>
Codeforces Round #305 (Div. 1) B. Mike and Feet(单调栈)
查看>>
NC15553 数学考试(线性DP)
查看>>
MySQL隐藏文件.mysql_history风险
查看>>
js求阶乘
查看>>
小程序图片正确使用方式(防止发布之后不显示)
查看>>
Java学习
查看>>
Js函数
查看>>
L1-009 N个数求和 (20 分)
查看>>
L2-031 深入虎穴 (25 分)
查看>>
Unity之PlayerPrefs
查看>>
简单的xml读取存储方法(未优化)
查看>>
Making the grade 和Sonya and Problem Wihtout a Legend
查看>>