poj 2230 Watchcow(欧拉回路)
关键是每条边必须走两遍,重复建边即可,因为确定了必然存在 Euler Circuit ,所以所有判断条件都不需要了。
注意:我是2500ms跑过的,鉴于这道题ac的code奇短,速度奇快,考虑解法应该不唯一。
1 #include<cstdio> 2 #include<cstring> 3 #include<vector> 4 #include<stack> 5 #include<algorithm> 6 #define rep(i,a,b) for(int i=a;i<=b;i++) 7 #define clr(a,m) memset(a,m,sizeof(a)) 8 using namespace std; 9 10 const int MAXN=11111; 11 const int MAXM=55555; 12 13 struct Edge{ 14 int v,next,vis; 15 Edge(){} 16 Edge(int _v,int _next):v(_v),next(_next),vis(0){} 17 }edge[MAXM<<2]; 18 19 stack<int>stk; 20 int head[MAXN],tol; 21 int degree[MAXN]; 22 23 void init() 24 { 25 tol=0; 26 clr(head,-1); 27 } 28 29 void add(int u,int v) 30 { 31 edge[tol]=Edge(v,head[u]); 32 head[u]=tol++; 33 34 edge[tol]=Edge(u,head[v]); 35 head[v]=tol++; 36 } 37 38 void FindEuler(int u) 39 { 40 for(int i=head[u];i!=-1;i=edge[i].next) 41 { 42 int v=edge[i].v; 43 44 if(!edge[i].vis){ 45 edge[i].vis=edge[i^1].vis=1; 46 FindEuler(v); 47 stk.push(v); 48 } 49 } 50 } 51 52 void EulerCircuit(int n) 53 { 54 while(!stk.empty()) 55 stk.pop(); 56 FindEuler(0); 57 } 58 59 int main() 60 { 61 int n,m,x,y; 62 scanf("%d%d",&n,&m); 63 64 init(); 65 clr(degree,0); 66 rep(i,0,m-1){ 67 scanf("%d%d",&x,&y); 68 x--;y--; 69 add(x,y); 70 add(x,y); 71 degree[x]+=2; 72 degree[y]+=2; 73 } 74 75 EulerCircuit(n); 76 stk.push(0); 77 while(!stk.empty()) 78 { 79 x=stk.top();stk.pop(); 80 printf("%d\n",x+1); 81 } 82 return 0; 83 }