POJ-1041 John's trip
生活随笔
收集整理的這篇文章主要介紹了
POJ-1041 John's trip
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
寫的時候思路很混亂,反復調試交了一發過了,后來才想清楚為啥
首先直接根據街道的值來排序從小到大排序,然后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的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MSP430低功耗模式-while循环失
- 下一篇: POJ - 1386 Play on W