一笔画问题模版!
#include<iostream> #include<stack> #include<cstdio> #include<cstring> using namespace std; #define M 1005 stack<int> s; int r[M][M]; int du[M]; int n=0,m; void dfs(int x) { for (int i=1;i<=n;i++) { if (r[x][i]) { r[x][i]--;r[i][x]--; dfs(i); } } s.push(x); } int main() { scanf("%d",&m); for (int i=1;i<=m;i++) { int x,y; scanf("%d%d",&x,&y); n=max(y,max(n,x)); du[x]++;du[y]++; r[x][y]++;r[y][x]++; } int sta=1; for (int i=1;i<=n;i++) if (du[i]%2==1){sta=i;break;} dfs(sta); while(!s.empty()) printf("%d\n",s.top()),s.pop(); return 0; }