hdu1814 Peaceful Commission

题意:2-sat裸题,打印字典序最小的


我写了三个

  1. 染色做法,正解
  2. scc做法,不管字典序
  3. scc做法,错误的字典序贪心
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
const int N = 2e4+5, M = 1e5+5; inline int read() {
int x = 0, f = 1; char c = getchar();
while(c<'0' || c>'9') {if(c=='-') f=-1; c=getchar();}
while(c>='0' && c<='9') {x=x*10+c-'0'; c=getchar();}
return x * f;
} int n, m;
struct edge {int v, ne;} e[M];
int cnt, h[N];
inline void ins(int u, int v) {
e[++cnt] = (edge) {v, h[u]}; h[u] = cnt;
}
inline int id(int x) {return ((x-1)^1)+1;}
int col[N], st[N], top;
bool dfs(int u) {
if(col[u]) return true;
if(col[id(u)]) return false;
col[u] = 1; st[top++] = u;
for(int i=h[u]; i; i=e[i].ne) {
int v = e[i].v;
if(!dfs(v)) return false;
}
return true;
}
bool check(int u) {
top = 1;
return dfs(u);
}
int main() {
freopen("in", "r", stdin);
while(cin >> n) {
cnt = 0;
memset(h, 0, sizeof(h));
memset(col, 0, sizeof(col));
m = read();
for(int i=1; i<=m; i++) {
int a = read(), b = read();
ins(a, id(b));
ins(b, id(a));
}
int flag = 0;
for(int i=1; i<=n<<1; i+=2) if(!col[i] && !col[id(i)]) {
if(!check(i)) {
while(top) col[ st[top--] ] = 0;
//for(int i=1; i<=n; i++) printf("col %d %d\n", i, col[i]);
if(!check(id(i))) {
puts("NIE"), flag = 1;
break;
}
}
}
if(flag) continue;
for(int i=1; i<=n<<1; i+=2) {
if(col[i]) printf("%d\n", i);
else printf("%d\n", i+1);
}
}
}
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
const int N = 2e4+5, M = 1e5+5; inline int read() {
int x = 0, f = 1; char c = getchar();
while(c<'0' || c>'9') {if(c=='-') f=-1; c=getchar();}
while(c>='0' && c<='9') {x=x*10+c-'0'; c=getchar();}
return x * f;
} int n, m;
struct edge {int v, ne;} e[M];
int cnt, h[N];
inline void ins(int u, int v) {
e[++cnt] = (edge) {v, h[u]}; h[u] = cnt;
}
int dfn[N], dfc, scc, belong[N], low[N];
int st[N], top;
void dfs(int u) {
dfn[u] = low[u] = ++dfc;
st[++top] = u;
for(int i=h[u]; i; i=e[i].ne) {
int v = e[i].v;
if(!dfn[v]) {
dfs(v);
low[u] = min(low[u], low[v]);
} else if(!belong[v]) low[u] = min(low[u], dfn[v]);
}
if(dfn[u] == low[u]) {
scc++;
while(true) {
int x = st[top--];
belong[x] = scc;
if(x == u) break;
}
}
}
namespace G {
edge e[M];
int cnt, h[N], ind[N];
inline void ins(int u, int v) {
e[++cnt] = (edge) {v, h[u]}; h[u] = cnt;
ind[v] ++;
}
int q[N], head = 1, tail = 1;
#define pii pair<int, int>
#define fir first
#define sec second
//priority_queue<pii, vector<pii>, greater<pii> > q;
int col[N], opp[N];
void dfs_color(int u) {
if(col[u]) return;
col[u] = -1;
for(int i=h[u]; i; i=e[i].ne) dfs_color(e[i].v);
}
bool check() {
for(int i=1; i<=n; i++) if(belong[i] == belong[i+n]) return false;
return true;
}
void topo_sort() {
head = tail = 1;
for(int i=1; i<=scc; i++) if(!ind[i]) q[tail++] = i;
while(head != tail) {
int u = q[head++]; printf("uuu %d %d\n", u, col[u]);
if(col[u]) continue;
col[u] = 1;
dfs_color(opp[u]);
for(int i=h[u]; i; i=e[i].ne) {
int v = e[i].v;
ind[v] --;
if(ind[v] == 0) q[tail++] = v;
}
}
}
}
int main() {
freopen("in", "r", stdin);
while(cin >> n) {
m = read();
for(int i=1; i<=m; i++) {
int a = read(), b = read();
ins(a, b+n);
ins(b, a+n);
}
for(int i=1; i<=n<<1; i++) if(!dfn[i]) dfs(i);
if(!G::check()) {
puts("NIE");
continue;
}
for(int u=1; u<=n<<1; u++) {
int a = belong[u];
for(int i=h[u]; i; i=e[i].ne) {
int b = belong[e[i].v];
if(a != b) ins(b, a);
}
}
for(int i=1; i<=n; i++) {
int a = belong[2*i-1], b = belong[2*i];
G::opp[a] = b;
G::opp[b] = a;
printf("hi %d %d %d\n", i, belong[a], belong[b]);
}
G::topo_sort();
for(int i=1; i<=n<<1; i++)
if(G::col[belong[i]] == 1) printf("%d\n", i);
}
}
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
const int N = 2e4+5, M = 1e5+5; inline int read() {
int x = 0, f = 1; char c = getchar();
while(c<'0' || c>'9') {if(c=='-') f=-1; c=getchar();}
while(c>='0' && c<='9') {x=x*10+c-'0'; c=getchar();}
return x * f;
} int n, m;
struct edge {int v, ne;} e[M];
int cnt, h[N];
inline void ins(int u, int v) {
e[++cnt] = (edge) {v, h[u]}; h[u] = cnt;
}
int dfn[N], dfc, scc, belong[N], low[N];
int st[N], top;
void dfs(int u) { //printf("dfs %d\n", u);
dfn[u] = low[u] = ++dfc;
st[++top] = u;
for(int i=h[u]; i; i=e[i].ne) {
int v = e[i].v;
if(!dfn[v]) {
dfs(v);
low[u] = min(low[u], low[v]);
} else if(!belong[v])
low[u] = min(low[u], dfn[v]);
}
if(dfn[u] == low[u]) {
scc++;
while(true) {
int x = st[top--];
belong[x] = scc;
if(x == u) break;
}
}
}
inline int id(int x) {
int t = ((x-1) >> 1) + 1;
if(x == t<<1) return x-1;
else return x+1;
}
int mn[N];
namespace G {
edge e[M];
int cnt, h[N], ind[N];
inline void ins(int u, int v) {
e[++cnt] = (edge) {v, h[u]}; h[u] = cnt;
ind[v] ++;
}
//int q[N], head = 1, tail = 1;
#define pii pair<int, int>
#define fir first
#define sec second
priority_queue<pii, vector<pii>, greater<pii> > q;
int col[N], opp[N];
void dfs_color(int u) {
if(col[u]) return;
col[u] = -1;
for(int i=h[u]; i; i=e[i].ne) dfs_color(e[i].v);
}
bool check() {
for(int i=1; i<=n; i++) if(belong[(i<<1)-1] == belong[i<<1]) return false;
return true;
}
void topo_sort() {
for(int i=1; i<=scc; i++) if(!ind[i]) q.push(make_pair(mn[i], i));
while(!q.empty()) {
int u = q.top().sec; q.pop(); printf("uuu %d %d\n", u, mn[u]);
if(col[u]) continue;
col[u] = 1;
dfs_color(opp[u]);
for(int i=h[u]; i; i=e[i].ne) {
int v = e[i].v;
ind[v] --;
if(ind[v] == 0) q.push(make_pair(mn[v], v));
}
}
}
}
int main() {
freopen("in", "r", stdin);
while(cin >> n) {
memset(dfn, 0, sizeof(dfn));
memset(low, 0, sizeof(low));
memset(belong, 0, sizeof(belong)); dfc = scc = 0;
cnt = 0; G::cnt = 0;
memset(h, 0, sizeof(h));
memset(G::h, 0, sizeof(G::h));
memset(G::col, 0, sizeof(G::col));
memset(G::ind, 0, sizeof(G::ind));
memset(mn, 0x3f, sizeof(mn)); m = read();
for(int i=1; i<=m; i++) {
int a = read(), b = read();
ins(a, id(b));
ins(b, id(a));
//printf("id %d %d\n", id(a), id(b));
}
for(int i=1; i<=n<<1; i++) if(!dfn[i]) dfs(i);
if(!G::check()) {
puts("NIE");
continue;
}
for(int u=1; u<=n<<1; u++) {
int a = belong[u];
mn[a] = min(mn[a], u);
for(int i=h[u]; i; i=e[i].ne) {
int b = belong[e[i].v];
if(a != b) G::ins(b, a);
}
}
//for(int i=1; i<=n<<1; i++) printf("belong %d %d %d\n", i, belong[i], mn[belong[i]]);
for(int i=1; i<=n; i++) {
int a = belong[(i<<1)-1], b = belong[i<<1];
G::opp[a] = b;
G::opp[b] = a;
//printf("hi %d %d %d\n", i, belong[a], belong[b]);
}
G::topo_sort();
//for(int i=1; i<=n<<1; i++) printf("col %d %d %d\n", i, belong[i], G::col[i]);
for(int i=1; i<=n<<1; i+=2) {
if(G::col[belong[i]] == 1) printf("%d\n", i);
else printf("%d\n", id(i));
}
}
}

hdu1814 Peaceful Commission的更多相关文章

  1. HDU1814 Peaceful Commission 2-sat

    原文链接http://www.cnblogs.com/zhouzhendong/p/8099115.html 题目传送门 - HDU1814 题面 Description 根据宪法,Byteland民 ...

  2. HDU-1814 Peaceful Commission 2sat

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1814 简单的2sat题. //STATUS:C++_AC_390MS_996KB #include & ...

  3. hdu1814 Peaceful Commission,2-sat

    题目大意:一国有n个党派.每一个党派在议会中都有2个代表,现要组建和平委员会,要从每一个党派在议会的代表中选出1人,一共n人组成和平委员会.已知有一些代表之间存在仇恨,也就是说他们不能同一时候被选为和 ...

  4. hdu1814 Peaceful Commission——2-SAT

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1814 第一次的2-SAT,推荐博客:https://blog.csdn.net/jarjingx/arti ...

  5. HDU1814(Peaceful Commission) 【2-SAT DFS暴力求最小字典序的模板】

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1814 题意:给出一个数n,代表有n个党派,每个党派要求派出其中一个人去参加会议,且只能派出一人.给出m ...

  6. HDU 1814 Peaceful Commission / HIT 1917 Peaceful Commission /CJOJ 1288 和平委员会(2-sat模板题)

    HDU 1814 Peaceful Commission / HIT 1917 Peaceful Commission /CJOJ 1288 和平委员会(2-sat模板题) Description T ...

  7. hdu 1814 Peaceful Commission (2-sat 输出字典序最小的路径)

    Peaceful Commission Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Oth ...

  8. Peaceful Commission

    Peaceful Commission Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...

  9. HDOJ 1814 Peaceful Commission

    经典2sat裸题,dfs的2sat能够方便输出字典序最小的解... Peaceful Commission Time Limit: 10000/5000 MS (Java/Others)    Mem ...

随机推荐

  1. R-----shiny包的部分解释和控件介绍

    R-----shiny包的部分解释和控件介绍 作者:周彦通.贾慧 shinyApp( ui = fixedPage( fixedPanel( top = 50, right=50, width=200 ...

  2. iTOP-4412/4418/6818开发板-fastboot烧写脚本

    在 iTOP-4412,4418,6818 开发板烧写的时候,使用的是 fastboot 工具. fastboot 工具需要在 cmd.exe 中调用,每次都需要输入烧写命令,这样步骤有点多.在程序员 ...

  3. 20175204 张湲祯 2018-2019-2《Java程序设计》第七周学习总结

    20175204 张湲祯 2018-2019-2<Java程序设计>第七周学习总结 教材学习内容总结 -第八章常用实用类要点: 一.String类: 1.String类所在的包:java. ...

  4. Java继承详解

    目录 前言 继承的格式: 继承的特点: 继承的优缺点 继承的注意点(重要) 继承的使用 前言 类是对对象的抽象,具有共同属性和行为的许多对象抽象出一个类. 例如:有三个学生小明,小红,小李都有姓名,年 ...

  5. php获取脚本执行的参数

    在看PHP文档到预定义变量时碰到了$argc和$argv,顺手记录下 getopt()从命令行参数列表中获取选项 $arg = getopt('d:n:'); //只接收d n之后的参数 $num = ...

  6. 肺结节CT影像特征提取(五)——肺结节CT影像ROI区域灰度直方图及其图形化

    在博客肺结节CT影像特征提取中,已经实现了肺结节的灰度.纹理和形态特征的提取.但是,对于进一步了解ROI区域像素值或者说CT值的分布来说,还存在一定的不足,不能够很好的显示ROI区域. 因此,本文将进 ...

  7. emos邮件系统的web密码修改方法

     作者:邓聪聪 1.修改web管理界面的登陆密码,数据库修改管理员密码,有root用root,没root用系统用户.查看方法 进入数据库查看到管理表项中的root管理账户信息, mysql> u ...

  8. excel2json

    原文链接 在游戏项目中一般都需要由策划制作大量的游戏内容,其中很大一部分是使用Excel表来制作的.于是程序就需要把Excel文件转换成程序方便读取的格式. 之前项目使用的Excel表导入工具都是通过 ...

  9. 收集Typecho 0.9还能用的插件

    收集Typecho 0.9还能用的插件 名称 描述 版本 作者 BaiduSubmit 百度结构化插件 for Typecho 0.5.2 老高 CateFilter 首页过滤指定分类 1.2.1 R ...

  10. UltraEdit注册机 及使用方法详解

    转载自:http://www.iyaxi.com/ultraedit-key/ UltraEdit是一款强大的文字编辑器,很多编程的.搞设计的等等都能用到它,具体功能请自行百度.今天为大家带来UE软件 ...