日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

POJ-1041 John's trip

發布時間:2023/11/27 生活经验 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。