其他分享
首页 > 其他分享> > 2-SAT模板

2-SAT模板

作者:互联网

K

#include <iostream>
#include <cstdio>
using namespace std;
const int N = 30010;
int n, m, head[N], ver[N << 1], nex[N << 1], tot, dfn[N], colCnt, col[N], sta[N], top, vis[N], low[N], cnt, ans[N];
inline void add (int x, int y) {
	ver[++ tot] = y;
	nex[tot] = head[x];
	head[x] = tot;
}
void tarjan (int x) {
	dfn[x] = low[x] = ++ cnt;
	sta[++ top] = x;
	vis[x] = 1;
	for (int i = head[x]; i; i = nex[i]) {
		int y = ver[i];
		if (!dfn[y]) {
			tarjan(y);
			low[x] = min(low[x], low[y]);
		} else if (vis[y])
			low[x] = min(low[x], low[y]);
	}
	if (dfn[x] == low[x]) {
		col[x] = ++ colCnt;
		vis[x] = 0;
		while (sta[top] != x) {
			col[sta[top]] = colCnt;
			vis[sta[top --]] = 0;
		}
		top --;
	}
}
void dfs (int x) {
	if (ans)
	for (int i = head[x]; i; i = nex[i]) {
		int y = ver[i];
	}
}
int main () {
	scanf("%d%d", &n, &m);
	for (int i = 1; i <= m; i ++) {
		int a[4], b[4];
		char c[10];
		scanf("%d %s %d %s %d %s", &a[1], c + 1, &a[2], c + 2, &a[3], c + 3);
		for (int j = 1; j <= 3; j ++)
			b[j] = (c[j] == 'B');
		add(a[1] * 2 - 1 + b[1], a[2] * 2 - b[2]);
		add(a[2] * 2 - 1 + b[2], a[1] * 2 - b[1]);
		add(a[1] * 2 - 1 + b[1], a[3] * 2 - b[3]);
		add(a[3] * 2 - 1 + b[3], a[1] * 2 - b[1]);
		add(a[2] * 2 - 1 + b[2], a[3] * 2 - b[3]);
		add(a[3] * 2 - 1 + b[3], a[2] * 2 - b[2]);
	}
	for (int i = 1; i <= 2 * n; i ++)
		if (!dfn[i])
			tarjan(i);
	int flag = 0;
	for (int i = 1; i <= 2 * n; i += 2)
		if (col[i] == col[i + 1])
			flag = 1;
	if (flag) {
		printf("-1\n");
		return 0;
	}
	for (int i = 1; i <= n * 2; i ++) vis[i] = 0;
	for (int i = 1; i <= n; i ++) {
		int c1 = col[i * 2 - 1], c2 = col[i * 2];
		if (vis[c1]) {
			ans[i] = 0;
			continue;
		}
		if (vis[c2]) {
			ans[i] = 1;
			continue;
		}
		if (c1 < c2) {
			ans[i] = 0;
			vis[c1] = 1;
		} else {
			ans[i] = 1;
			vis[c2] = 1;
		}
	}
	for (int i = 1; i <= n; i ++) {
		if (ans[i]) printf("R");
		else printf("B");
	}
	printf("\n");
	return 0;
}

标签:std,head,const,30010,int,include,模板,SAT
来源: https://www.cnblogs.com/duoluoluo/p/16468540.html