Submission #1007237

# Submission time Handle Problem Language Result Execution time Memory
1007237 2024-06-24T13:36:13 Z Mardonbekhazratov Dreaming (IOI13_dreaming) C++17
0 / 100
36 ms 16980 KB
#include "dreaming.h"
#include<bits/stdc++.h>

using namespace std;

#define ll long long

int n,m,l;
vector<int>sz;
vector<bool>vis;
vector<vector<pair<int,int>>>v;

int dfs(int x){
    vis[x]=true;
    sz[x]=0;
    for(auto [z,w]:v[x]){
        if(!vis[z]){
            sz[x]=max(sz[x],dfs(z)+w);
        }
    }
    return sz[x];
}

int mn;

void dfs2(int x,int y=0){
    vis[x]=true;
    multiset<int>s;
    s.insert(y);
    for(auto [z,w]:v[x]){
        if(!vis[z]){
            s.insert(sz[z]+w);
        }
    }
    mn=min(mn,*s.rbegin());
    for(auto [z,w]:v[x]){
        if(!vis[z]){
            s.erase(s.find(sz[z]+w));
            dfs2(z,*s.rbegin()+w);
            s.insert(sz[z]+w);
        }
    }
}

int travelTime(int N, int M, int L, int A[], int B[], int T[]) {
    n=N;
    m=M;
    l=L;
    v.assign(n,{});
    for(int i=0;i<m;i++){
        v[A[i]].push_back({B[i],T[i]});
        v[B[i]].push_back({A[i],T[i]});
    }
    sz.resize(n);
    vis.assign(n,false);
    for(int i=0;i<n;i++){
        if(!vis[i]){
            dfs(i);
        }
    }
    vector<int>a;
    vis.assign(n,false);
    for(int i=0;i<n;i++){
        if(!vis[i]){
            mn=(int)1e9;
            dfs2(i);
            a.push_back(mn);
        }
    }
    if(a.size()==1){
        ;
    }
    sort(a.begin(),a.end());
    return a[a.size()-1]+a[a.size()-2]+l;
}
# Verdict Execution time Memory Grader output
1 Incorrect 36 ms 16980 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 0 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 36 ms 16980 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 18 ms 5720 KB Output is correct
2 Incorrect 18 ms 5720 KB Output isn't correct
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 0 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 36 ms 16980 KB Output isn't correct
2 Halted 0 ms 0 KB -