nyoj1006(最短路次短路spfa)
阿新 • • 發佈:2018-12-30
偷西瓜
時間限制:1000 ms | 記憶體限制:65535 KB 難度:4- 描述
-
對於農村的孩子來說最大的樂趣,莫過於和小夥伴們一塊下地偷西瓜了,雖然孩子們條件不是很好,但是往往他們很聰明,他們總在計算著到達瓜田的距離,以及逃跑的路線,他們總是以最短的距離衝到瓜田裡面,然後以最短的距離回到出發的地方,不過瓜田的大人們已經在他們來的路上等待他們。於是聰明的小夥伴們便不走過的路,即每條路只走一遍,如果小夥伴們回不到出發的地方,他們就說“eating”,
我們假設 有 n (n<=100)個 村莊 m條路(m<=1000)小夥伴們總是從1號村莊出發,而瓜田總是在n號村莊.如果小夥伴們到達不了n號村莊,或者回不到1號村莊請輸出"eating";
- 輸入
- 多組資料
第一行一個整數 n
第二行 一個整數 m
隨後的m行 有 三個數u,v,w 表示u 到 v村莊的距離為w(w<=1000); - 輸出
- 求小夥伴們從1號村莊出發,到 n號村莊,再回到1號村莊所用的最短距離,如果不能回到1號村莊請輸出“eating”.
- 樣例輸入
-
2 1 1 2 999 3 3 1 3 10 2 1 20 3 2 50
- 樣例輸出
-
eating 80
- 上傳者
分析:求一個最短路和一個次短路的和。
那麼我們用spfa求一次從1到n的最短路,然後順便記錄路徑,然後求完之後把走過的路徑刪去。然後在求一次1到n的最短路。
spfa講解:http://blog.csdn.net/y990041769/article/details/18367665
程式碼:
[cpp] view plaincopyprint?- #include <cstdio>
- #include <vector>
- #include <iostream>
- #include <stack>
- #include <cstdio>
- #include <string>
- #include <cstring>
- #include <cmath>
- #include <algorithm>
- #include <queue>
-
usingnamespace
- constint inf = 0x3f3f3f3f;
- constint N = 300;
- struct Point
- {
- int x,y;
- int r;
- int num;
- };
- Point a[N];
- struct Node
- {
- int v,len;
- };
- vector<Node> map[N];
- int n,m;
- void spfa(int s,int dis[])
- {
- int i,pre[N];
- bool used[N];
- queue<int> q;
- memset(used,0,sizeof(used));
- memset(pre,-1,sizeof(pre));
- for(i=0; i<N; i++)
- dis[i]=inf;
- dis[s]=0;
- used[s]=true;
- q.push(s);
- while(!q.empty())
- {
- int u=q.front();
- q.pop();
- used[u]=false;
- for(i=0; i<map[u].size(); i++)
- {
- Node p=map[u][i];
- if(dis[p.v]>dis[u]+p.len)
- {
- dis[p.v]=dis[u]+p.len;
- pre[p.v]=u;
- if(!used[p.v])
- {
- used[p.v]=true;
- q.push(p.v);
- }
- }
- }
- }
- for(int i=n;pre[i]!=-1;i=pre[i])
- {
- // printf("%d ",pre[i]);
- for(int j=0;j<map[i].size();j++)
- {
- if(map[i][j].v==pre[i])
- map[i].erase(map[i].begin()+j);
- }
- for(int j=0;j<map[pre[i]].size();j++)
- {
- if(map[pre[i]][j].v==i)
- map[pre[i]].erase(map[pre[i]].begin()+j);
- }
- }
- }
- int main()
- {
- int dis1[N];
- while(~scanf("%d%d",&n,&m))
- {
- for(int i=0;i<=n;i++)
- map[i].clear();
- for(int i=0;i<m;i++)
- {
- int x,y,z;
- scanf("%d%d%d",&x,&y,&z);
- Node tmp;
- tmp.v=y,tmp.len=z;
- map[x].push_back(tmp);
- tmp.v=x;
- map[y].push_back(tmp);
- }
- int ans=0;
- spfa(1,dis1);
- ans+=dis1[n];
- spfa(1,dis1);
- ans+=dis1[n];
- if(ans>=inf)
- printf("eating\n");
- else
- printf("%d\n",ans);
- }
- return 0;
- }