Description
这是一个小明认为很难的问题,快到五一长假了,小明突然想去旅游,但是他有一些想去的地方,他搜集了他想去的地方的路线信息,但是他搜集的信息太多了,因此他决定把制定路线的事情交给你(他的大管家)。为了描述方便,我们将他可能要经过的n个城市编号1,2,…, n,当然他要求他到目的地所需的时间最短。
Input
一共有t组数据,每组数据的第一行有两个正整数n, m,(n<=1000,m<=10000)分别表示城市的数量和路的条数,接下来m行,每行有三个整数a,b,c,(1=<a,b<=n ,0<c<100), 分别表示城市a和 城市b之间有一条路要花c的时间,最后一行的两个整数s,e,代表小明的起始点和目的地。
Output
输出一路上要花掉的时间,当然由于时间仓促,有可能搜集的信息不能到达目的地,这时请输出-1
Sample Input
2
3 2
1 2 2
2 3 3
1 3
4 2
1 2 3
1 3 2
1 4
Sample Output
5
-1
思路:bfs搜索,动态更新起点到其他点的最少时间即可。注意处理一下重边的问题,也就是说两个点之间有多条路径,取其最短长度。
#include<bits/stdc++.h>
using namespace std;
#define pi acos(-1)
#define mod 1000000007
#define INF 0x3f3f3f
#define fi first
#define se second
#define it iterator
#define ins insert
#define mp make_pair
#define pb push_back
#define lb lower_bound
#define ub upper_bound
#define np next_permutation
#define pq priority_queue
#define ll long long
#define ull unsigned long long
#define mem(a,x) memset(a,x,sizeof(a))
#define cio ios::sync_with_stdio(false) // 不能和C的输入混用
inline ll gcd(ll a,ll b){
return b == 0