Pagini recente » Cod sursa (job #2824507) | Cod sursa (job #2710557) | Cod sursa (job #2847471) | Cod sursa (job #2965205) | Cod sursa (job #3270528)
#include <iostream>
#include <fstream>
#include <vector>
#include <queue>
#include <algorithm>
#define inf 2e9
using namespace std;
ifstream f("camionas.in");
ofstream g("camionas.out");
vector <pair<int,int> > v[50001];
priority_queue <pair<int,int>,vector <pair<int,int> >,greater <pair <int,int> > >h;
int d[50001],n,m,x,y,c,i,gr;
void dijkstra(int s)
{int i,nod,vecin,cost;
for(i=1;i<=n;i++)d[i]=inf;
d[s]=0;
h.push(make_pair(0,s));
while(!h.empty())
{nod=h.top().second;
cost=h.top().first;
h.pop();
if(d[nod]!=cost)continue;
for(pair <int,int> i:v[nod])
{vecin=i.second;
cost=i.first;
if(d[nod]+cost<d[vecin])
{d[vecin]=d[nod]+cost;
h.push(make_pair(d[vecin],vecin));
}
}
}
}
int main()
{f>>n>>m>>gr;
for(i=1;i<=m;i++)
{f>>x>>y>>c;
if(c>=gr)
{v[x].push_back(make_pair(0,y));
v[y].push_back(make_pair(0,x));}
else {v[x].push_back(make_pair(1,y));
v[y].push_back(make_pair(1,x));}
}
dijkstra(1);
sort(d+1,d+n+1);
g<<d[n];
return 0;
}