題目大意:給你一張無向圖,每一個點的度數都是3。
你的任務是推斷是否能把它分解成若干個爪(每條邊僅僅能屬於一個爪)
解題思路:二分圖染色裸題。能夠得出:爪的中心點和旁邊的三個點的顏色是不一樣的
#include <cstdio>
#include <cstring>
using namespace std;
#define N 310
#define M 2010
struct Edge{
int to, Next;
}E[M];
int head[N], color[N], tot;
int n, m;
void AddEdge(int from, int to) {
E[tot].to = to;
E[tot].Next = head[from];
head[from] = tot++;
}
void init() {
memset(head, -1, sizeof(head));
tot = 0;
int u, v;
while (scanf("%d%d", &u, &v) && u + v) {
AddEdge(u, v);
AddEdge(v, u);
}
}
bool bipartite(int u) {
for (int i = head[u]; i != -1; i = E[i].Next) {
int v = E[i].to;
if (color[v] == color[u])
return false;
if (!color[v]) {
color[v] = 3 - color[u];
if (!bipartite(v))
return false;
}
}
return true;
}
void solve() {
memset(color, 0, sizeof(color));
color[1] = 1;
if (bipartite(1))
printf("YES\n");
else
printf("NO\n");
}
int main() {
while (scanf("%d", &n) != EOF && n) {
init();
solve();
}
return 0;
}