码迷,mamicode.com
首页 > 其他好文 > 详细

骑马修栅栏--一种较为慢的做法

时间:2017-03-15 14:44:31      阅读:241      评论:0      收藏:0      [点我收藏+]

标签:ios   repr   map   ==   word   nbsp   cli   i++   bre   

一种挺简单的做法,欧拉标准算法,贴上程序

vvvvvv

#include<iostream>
#include<cstring>
#include<string>
#include<fstream>
#include<queue>
#include<climits>
#include<vector>
using namespace std;
int Max(int a,int b) { return a>b?a:b; }
int Min(int a,int b) { return a<b?a:b; }
int map[505][505];
int path[1050];
int pathnum;
int minv=INT_MAX,maxv=0;
void Euler_circle_u(int v)
{
for (int i=minv;i<=maxv;i++)
while(map[i][v]>0)
{
map[i][v]--;
map[v][i]--;
Euler_circle_u(i);
}
path[pathnum++]=v;
}
int main(){
int f;
cin>>f;
memset(map,0,sizeof(map));
for (int i=0;i<f;i++)
{
int a,b;
cin>>a>>b;
minv=Min(a,minv);
minv=Min(b,minv);
maxv=Max(a,maxv);
maxv=Max(b,maxv);
map[a][0]++;
map[b][0]++;
map[a][b]++;
map[b][a]++;
}
int k=minv;
for (int i=minv;i<=maxv;i++)
if (map[i][0]%2==1)
{
k=i;
break;
}
Euler_circle_u(k);
for (int i=pathnum-1;i>=0;i--)
cout<<path[i]<<endl;
return 0;

骑马修栅栏--一种较为慢的做法

标签:ios   repr   map   ==   word   nbsp   cli   i++   bre   

原文地址:http://www.cnblogs.com/fkwhite/p/6553791.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!