栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

poj 2113 Agents

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

poj 2113 Agents

#include <stdio.h>#include <string.h>#include <algorithm>#define MAXN 512using namespace std;bool w[MAXN][MAXN];int tot[MAXN];int father[MAXN];int list[MAXN];bool set[3][MAXN];int inset[MAXN];int n,m;int findfather(int node){return node==father[node]?node:(father[node]=findfather(father[node]));}void Union(int node1,int node2){father[findfather(node2)]=findfather(node1);}int cmp(int a,int b){return findfather(a)==findfather(b)?(tot[a]>tot[b]):(findfather(a)<findfather(b));}bool search(int num){if (num>=n || father[list[num]]!=father[list[num-1]]) return true;int i,j,node=list[num];bool temp[MAXN];for (i=0;i<3;i++){if (set[i][node]){inset[node]=i;memcpy(temp,set[i],sizeof temp);for (j=0;j<n;j++)if (!w[node][j]) set[i][j]=false;if (search(num+1)) return true;memcpy(set[i],temp,sizeof temp);}}return false;}int main(){int i,j,k;while (scanf("%d%d",&n,&m),n){memset(w,true,sizeof w);memset(tot,0,sizeof tot);for (i=0;i<n;i++){father[i]=i;list[i]=i;}while (m--){scanf("%d%d",&i,&j);Union(i,j);tot[i]++;tot[j]++;w[i][j]=w[j][i]=false;}sort(list,list+n,cmp);for (i=0;i<n;){inset[list[i]]=0;memcpy(set[0],w[list[i]],sizeof set[0]);memset(set[1],true,2*sizeof set[0]);if (!search(++i)) break;while (i<n && father[list[i]]==father[list[i-1]])i++;}if (i<n)puts("The agents cannot be split");else {for (i=0;i<n-1;i++)printf("%d ",inset[i]);printf("%dn",inset[n-1]);}}return 0;}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/375532.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号