标签:blog 存在 欧拉路 pos art 路径 dfs class 欧拉
1 //欧拉路 2 3 #include<iostream> 4 #include<cstdio> 5 using namespace std; 6 int maps[1001][1001]; 7 int flag[1001]; 8 int tot,n,m; 9 int ans[1001],p=0; 10 void dfs(int num){ 11 for(int i=1;i<=m;i++) 12 if(maps[num][i]==1) 13 { 14 maps[num][i]=0; 15 maps[i][num]=0; 16 dfs(i); 17 ans[++p]=i; 18 } 19 } 20 int main() 21 { 22 int a,b,flag1=0,start=1; 23 scanf("%d%d",&m,&n); 24 for(int i=1;i<=n;i++) 25 { 26 scanf("%d%d",&a,&b); 27 maps[a][b]=1; 28 maps[b][a]=1; 29 flag[a]++; 30 flag[b]++; 31 } 32 for(int i=1;i<=n;i++) 33 { 34 if(flag[i]%2!=0) 35 { 36 if(flag1==0) 37 start=i; 38 flag1++; 39 } 40 if(flag1>2) 41 { 42 printf("Impossible"); 43 return 0; 44 } 45 } 46 dfs(start);//必须从奇点开始搜 47 for(int i=1;i<=p;i++) 48 printf("%d ",ans[i]); 49 return 0; 50 }
欧拉回路:
似乎比欧拉路还水:从1开始搜的;
1 //欧拉回路 2 3 #include<iostream> 4 #include<cstdio> 5 using namespace std; 6 int maps[1001][1001]; 7 int flag[1001]; 8 int n,m; 9 int ans[1001],p=0; 10 void dfs(int num){//搜哦搜 11 for(int i=1;i<=m;i++) 12 if(maps[num][i]==1) 13 { 14 maps[num][i]=0; 15 maps[i][num]=0; 16 dfs(i); 17 ans[++p]=i; 18 } 19 } 20 int main() 21 { 22 int a,b,flag1=0; 23 scanf("%d%d",&m,&n); 24 for(int i=1;i<=n;i++) 25 { 26 scanf("%d%d",&a,&b); 27 maps[a][b]=1; 28 maps[b][a]=1; 29 flag[a]++; 30 flag[b]++; 31 } 32 for(int i=1;i<=n;i++) 33 { 34 if(flag[i]%2!=0) 35 { 36 printf("Impossible"); 37 return 0; 38 } 39 } 40 dfs(1);//满足的话从哪个点搜都可以; 41 for(int i=1;i<=p;i++) 42 printf("%d ",ans[i]); 43 printf("%d ",1); 44 return 0; 45 }
标签:blog 存在 欧拉路 pos art 路径 dfs class 欧拉
原文地址:http://www.cnblogs.com/sssy/p/6682871.html