考试2019-08-16

T1(disaster)
题目大意

有天,某个核蔼可氢的XX要被机惨了,他得知消息,很快的跑向机房,因为他不想太惨,所以他想跑最短的路跑回机房,他想知道他最少要跑多远才能到达机房解救他的账号。 号节点表机房, n号节点表示所在位置。

Input

第一行输入n,m。 n表示节点数, m表示路径数
第二行至m+1行每行三个数x,y,z,分别表示条双向路径的2个端点和长度

Output

一行一个整数,输出最小距离

Sample Input

4 6
1 2 2
2 3 2
2 4 1
1 3 5
3 4 3
1 4 4

Sample Output

3

思路:dijikstr板子题,只需要从每个点到1号点的最短路径跑一边,最后输出到点n的最短路径即可。

代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
using  namespace std;
const int maxn=600000+10,INF=2147483647;
int begin[maxn],next[maxn],to[maxn],w[maxn],dis[maxn],n,m,s,t,pre[maxn],cnt;
priority_queue<pair<int,int> >q;
void add(int x,int y,int v){//链式前向星存边
    to[++cnt]=y;
    next[cnt]=begin[x];
    begin[x]=cnt;
    w[cnt]=v;
}
void dijkstra(int s){
 	for(int i=1;i<=n;i++)
        dis[i]=INF;//初始化
    memset(pre,0,sizeof(pre));
    dis[s]=0;
    q.push(make_pair(0,s));
    while(q.size()){
        int x=q.top().second;
        q.pop();
        if(pre[x])
			continue;
        pre[x]=1;
        for(int i=begin[x];i;i=next[i]){
            int y=to[i];
            if(dis[y]>dis[x]+w[i]){
                dis[y]=dis[x]+w[i];
                q.push(make_pair(-dis[y],y));
            }
        }
    }
}
int main(){
	//freopen("diaster.in","r",stdin);
	//freopen("diaster.out","w",stdout);
	scanf("%d%d",&n,&m);
    for(int i=1;i<=m;i++){
    	int x,y,z;
    	scanf("%d%d%d",&x,&y,&z);
    	add(x,y,z);	
    }
    dijkstra(1);//计算每个点到一号点的最短距离
    printf("%d",dis[n]);//输出n号点到一号点的最短距离
	return  0;
}