Cod sursa(job #3270528)

Utilizator theo_aldescuTheodora Aldescu theo_aldescu Data 23 ianuarie 2025 17:16:44
Problema Heapuri Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.04 kb
#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; 
}