写的时候思路很混乱,反复调试交了一发过了,后来才想清楚为啥

首先直接根据街道的值来排序从小到大排序,然后dfs一下就能得到答案,但是问题在于自己对于跑dfs理解不深出现了问题,

1。从小到大排序

2。排序完按照从小到大建边

3。直接从1点开始跑dfs,跑完输出

但是问题是dfs跑要逆序输出,但是正向加边跑dfs是从逆着跑的,比如1->2,1->5,先跑了1->5,然后正序输出就是逆序加入逆序输出的答案

代码如下

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<math.h>
#include<set>
#include<stack>
#include<vector>
#include<map>
#include<queue>
#define myself i,l,r
#define lson i<<1
#define rson i<<1|1
#define Lson i<<1,l,mid
#define Rson i<<1|1,mid+1,r
#define half (l+r)/2
#define inff 0x3f3f3f3f
#define lowbit(x) x&(-x)
#define me(a,b) memset(a,b,sizeof(a))
#define min4(a,b,c,d) min(min(a,b),min(c,d))
#define min3(x,y,z) min(min(x,y),min(y,z))
#define max4(a,b,c,d) max(max(a,b),max(c,d))
#define max3(x,y,z) max(max(x,y),max(y,z))
typedef long long ll;
using namespace std;
const int maxn=2005;
struct node
{int to,p,vis;
}edge[maxn<<1];
struct nod
{int x,y,z;
}s[maxn];
bool cmp(nod s,nod e)
{return s.z<e.z;
}
int head[maxn],in[maxn],way[maxn];
int sign,cnt;
int n,m,ans[maxn];
void init()
{memset(in,0,sizeof(in));sign=0;cnt=m=n=0;
}
void add(int u,int v)
{edge[++sign]=node{v,head[u],0};head[u]=sign;
}
void dfs(int u)
{for(int i=head[u];i;i=head[u]){cout<<u<<" "<<edge[i].to<<endl;head[u]=edge[i].p;int v=edge[i].to;if(edge[i].vis)continue;edge[i].vis=1;if(i&1)edge[i+1].vis=1;elseedge[i-1].vis=1;dfs(v);ans[++cnt]=(i+1)/2;cout<<"ans["<<cnt<<"]"<<ans[cnt]<<endl;}
}
int main()
{int x,y,z;while(scanf("%d %d",&x,&y),x+y){init();scanf("%d",&z);n=max3(n,x,y);in[x]++,in[y]++;s[++m]=nod{x,y,z};while(scanf("%d %d",&x,&y),x+y){scanf("%d",&z);in[x]++,in[y]++;s[++m]=nod{x,y,z};n=max3(n,x,y);}int i;for(i=1;i<=n;i++)if(in[i]%2) {printf("Round trip does not exist.\n");break;}if(i!=n+1)  continue;sort(s+1,s+1+m,cmp);for(int i=m;i>=1;i--){add(s[i].x,s[i].y);add(s[i].y,s[i].x);}dfs(1);for(int i=1;i<=cnt;i++)printf("%d ",ans[i]);printf("\n");}return 0;
}

POJ-1041 John's trip相关推荐

  1. POJ 1041 John's trip(欧拉回路)

    本文链接:http://www.cnblogs.com/Ash-ly/p/5398549.html 题意: Johnny 有了一台新车,他想去访问他所有的朋友(赤裸裸的炫耀?),他的朋友有很多,住在城 ...

  2. POJ - 1041 John's trip(欧拉回路)

    题目链接:点击查看 题目大意:给出一张无向图,要求从起点开始遍历一遍所有的边,最后再回到起点,题目要求输出任意一组方案 细节: 起点不是点1,而是第一条边中两个端点中娇小的一个点 给出的x y z代表 ...

  3. John's trip(POJ1041+欧拉回路+打印路径)

    题目链接:http://poj.org/problem?id=1041 题目: 题意:给你n条街道,m个路口,每次输入以0 0结束,给你的u v t分别表示路口u和v由t这条街道连接,要输出从起点出发 ...

  4. poj 1041(欧拉回路+输出字典序最小路径)

    题目链接:http://poj.org/problem?id=1041 思路:懒得写了,直接copy吧:对于一个图可以从一个顶点沿着边走下去,每个边只走一次,所有的边都经过后回到原点的路.一个无向图存 ...

  5. 【POJ 1734】 Sightseeing Trip

    [题目链接] 点击打开链接 [算法] floyd求最小环 输出路径的方法如下,对于i到j的最短路,我们记pre[i][j]表示j的上一步 在进行松弛操作的时候更新pre即可 [代码] #include ...

  6. 图论--欧拉路,欧拉回路(小结)

    在题目中在慢慢细说概念 1.HDU - 3018 Ant Trip 题目大意:又N个村庄,M条道路.问须要走几次才干将全部的路遍历 解题思路:这题问的是有关欧拉路的判定 欧拉路就是每条边仅仅能走一次, ...

  7. 欧拉图简述---(一笔画问题)

    主要参考大佬博客:https://blog.csdn.net/u011815404/article/details/86590498 欧拉图 欧拉图是在大家小学时学奥数都学习过的一个类型的题,无论你学 ...

  8. 【转载】图论 500题——主要为hdu/poj/zoj

    转自--http://blog.csdn.net/qwe20060514/article/details/8112550 =============================以下是最小生成树+并 ...

  9. POJ前面的题目算法思路【转】

    1000 A+B Problem 送分题 49% 2005-5-7 1001 Exponentiation 高精度 85% 2005-5-7 1002 487-3279 n/a 90% 2005-5- ...

最新文章

  1. 技术人员如何转型为产品经理
  2. 【Python 自然语言处理 第二版】读书笔记2:获得文本语料和词汇资源
  3. MvcPager帮助文档 - MvcAjaxOptions 类
  4. python里的shell是什么_python中的shell操作
  5. Sharepoint学习笔记 –架构系列—12 Sharepoint的客户端对象模型(Client Object Model)
  6. android 音乐资源获取失败,android – 获取嵌入式mp3文件嵌入式艺术失败
  7. 支付宝认错,回应央行 18 万行政罚单!
  8. C#记事本的简单开发
  9. [Errno 256] No more mirrors to try.
  10. network 网络带宽
  11. 社交聊天平台完整版源码【vue前端+后台+完整数据库+完整文档教程】
  12. ubuntu安装WPS字体缺失的解决办法
  13. vs下qt混合编译错误:MOC问题
  14. iOS调用系统相机将英文改成中文
  15. .Net中Web增加加密狗管理
  16. 快手涨收近95港币,年初至今已涨超30%
  17. 90后都开始养生了,你怎么能少了这本宝典丨钛空舱
  18. 多机Nomad+Consul+consul-template+Nginx反向代理
  19. android 单位pt,Android APPUI设计师必知:pt sp dp之间的关系
  20. Linux上安装Nginx教程

热门文章

  1. python2x NameError: name ‘abc‘ is not defined
  2. Fragment 中使用 getLayoutInflater() 的问题
  3. 两下或多下回车造成数据库多次提交事物的解决方法
  4. android使用webview时按后退退出的问题
  5. 2022-2028年中国胶片手套行业市场研究及前瞻分析报告
  6. android 之 Intent、broadcast
  7. iOS 开发经验总结
  8. iter迭代器的应用
  9. 数据库SQL优化大总结之百万级数据库优化方案
  10. JSP--JavaBean