zoukankan      html  css  js  c++  java
  • POJ 3905 Perfect Election(2-sat)

    POJ 3905 Perfect Election

    题目链接

    思路:非常裸的2-sat,就依据题意建边就可以

    代码:

    #include <cstdio>
    #include <cstring>
    #include <cstdlib>
    #include <vector>
    #include <algorithm>
    using namespace std;
    
    const int MAXNODE = 2005;
    
    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;
    
    int n, m;
    
    int main() {
    	while (~scanf("%d%d", &n, &m)) {
    		gao.init(n);
    		int u, v;
    		while (m--) {
    			scanf("%d%d", &u, &v);
    			if (u > 0 && v > 0) {
    				u--; v--;
    				gao.add_Edge(u, 1, v, 1);
    			} else if (u > 0 && v < 0) {
    				v = -v;
    				u--; v--;
    				gao.add_Edge(u, 1, v, 0);
    			} else if (u < 0 && v > 0) {
    				u = -u;
    				u--; v--;
    				gao.add_Edge(u, 0, v, 1);
    			} else if (u < 0 && v < 0) {
    				u = -u; v = -v;
    				u--; v--;
    				gao.add_Edge(u, 0, v, 0);
    			}
    		}
    		printf("%d
    ", gao.solve());
    	}
    	return 0;
    }


  • 相关阅读:
    Sampling Distribution of the Sample Mean|Central Limit Theorem
    OS L2-3: Process Creation and Operations
    c++函数重载、内联函数、类、友元
    命名空间及异常处理
    C++继承与多态,代码复用之泛型和模板
    ORB_GMS图像对齐
    ORB对齐
    [转]OpenCV中ORB特征点检测和匹配简单用法
    [转]OpenCV学习笔记】之鼠标的调用
    [转]OpenCV—Mat类
  • 原文地址:https://www.cnblogs.com/liguangsunls/p/6905539.html
Copyright © 2011-2022 走看看