UVA 10004-Bicoloring(二染色)
835 ワード
使用する深さ検索、dfs();
点ごとに染色し,辺のある2点は不要な色を染め,それぞれ1,−1で表し,その点に関連する点が同じ色であるか否かを判断する.
コードが長くありません:
点ごとに染色し,辺のある2点は不要な色を染め,それぞれ1,−1で表し,その点に関連する点が同じ色であるか否かを判断する.
コードが長くありません:
#include
#include
using namespace std;
int n, in[250][250], visit[250];
int input()
{
memset(in,0,sizeof(in));
memset(visit,0,sizeof(visit));
int t;
cin>>t;
while(t--)
{
int a, b;
cin>>a>>b;
in[a][b] = 1;
in[b][a] = 1;
}
return 0;
}
int dfs(int u)
{
for(int i = 0; i < n; i++)
{
if(!visit[i]&&in[u][i]){visit[i] = -1*visit[u]; if(dfs(i)==-1)return -1;}
else if(in[u][i]&&visit[i]==visit[u])return -1;
}
return 0;
}
int main ()
{
while(cin>>n&&n)
{
input();
visit[0] = 1;
if(dfs(0)==-1)cout<