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 4Sample 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;
}