74282024-01-08 20:48:28horvathabelVillanyautócpp17Wrong answer 9/60279ms4428 KiB
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
ll mx=100000000001;
vector<pair<ll,ll>> g[101];
bool dijkstra(ll mxut, ll k, ll x, ll n){
    priority_queue<pair<ll,ll>, vector<pair<ll,ll>>, greater<pair<ll,ll>>> q;
    vector<ll> maxk;
    maxk.resize(n+1,0);
    q.push({0,x});
    vector<ll>t;
    t.resize(101, mx);
    t[x]=0;
    while (!q.empty()){
        auto v=q.top();
        q.pop();

        for (auto edge:g[v.second]){
                bool van=false;
                if (t[edge.first]>edge.second+v.first){
                    if (edge.second+v.first>mxut){
                        if (edge.second<=mxut){;
                            t[edge.first]=edge.second;
                            maxk[edge.first]=max(maxk[edge.first], maxk[v.second]+1);
                            van=true;
                        }
                    }
                    else{
                            t[edge.first]=edge.second+v.first;
                            van=true;
                            }
                    if (van) q.push({t[edge.first],edge.first});
                }
        }
    }
    for (ll i=1; i<=n;i++) if (maxk[i]>k || t[i]==mx)  return false;
    return true;
}
int main()
{
    ll n,m,k;
    cin>>n>>m>>k;
    ll r=0;
    for (ll i=0; i<m;i++){
        ll a, b,c;
        cin>>a>>b>>c;
        r+=c;
        g[a].push_back({b,c});
        g[b].push_back({a,c});
    }
    ll l=0;
    while (l+1!=r){
         ll m=(l+r)/2;
         bool good=true;
         for (ll i=1; i<=n;i++){
                good=dijkstra(m, k, i, n);
         }
         if (good) r=m;
         else l=m;
    }
    cout<<l+1<<endl;
}
SubtaskSumTestVerdictTimeMemory
base9/60
1Accepted0/03ms1816 KiB
2Accepted0/0107ms2392 KiB
3Wrong answer0/118ms2436 KiB
4Wrong answer0/139ms2744 KiB
5Wrong answer0/148ms2812 KiB
6Wrong answer0/279ms2884 KiB
7Wrong answer0/2165ms3316 KiB
8Wrong answer0/2279ms3532 KiB
9Accepted1/14ms3472 KiB
10Wrong answer0/14ms3344 KiB
11Wrong answer0/14ms3420 KiB
12Wrong answer0/212ms3644 KiB
13Wrong answer0/29ms3864 KiB
14Wrong answer0/26ms3968 KiB
15Wrong answer0/39ms4064 KiB
16Wrong answer0/314ms4112 KiB
17Wrong answer0/214ms4068 KiB
18Wrong answer0/235ms4104 KiB
19Wrong answer0/235ms4084 KiB
20Wrong answer0/248ms4108 KiB
21Accepted2/228ms4056 KiB
22Wrong answer0/28ms4032 KiB
23Wrong answer0/348ms4036 KiB
24Wrong answer0/3131ms4208 KiB
25Wrong answer0/3136ms4108 KiB
26Wrong answer0/3210ms4428 KiB
27Accepted3/3115ms4332 KiB
28Wrong answer0/348ms4152 KiB
29Wrong answer0/345ms4272 KiB
30Accepted3/352ms4384 KiB