Submission #712946

#TimeUsernameProblemLanguageResultExecution timeMemory
712946anhduc2701경주 (Race) (IOI11_race)C++98
Compilation error
0 ms0 KiB
/* #pragma GCC optimize("Ofast") #pragma GCC target("avx,avx2,fma") #pragma GCC optimize("unroll-loops") */ #include<bits/stdc++.h> #define int long long using namespace std; #define all(x) x.begin(), x.end() #define len(x) ll(x.size()) #define eb emplace_back #define PI 3.14159265359 #define fi first #define se second #define mp make_pair #define pb push_back #define MIN(v) *min_element(all(v)) #define MAX(v) *max_element(all(v)) #define BIT(x,i) (1&((x)>>(i))) #define MASK(x) (1LL<<(x)) #define task "tnc" typedef long long ll; const ll INF=1e18; const int maxn=1e6+5; const int mod=1e9+7; const int mo=998244353; using pi=pair<ll,ll>; using vi=vector<ll>; using pii=pair<pair<ll,ll>,ll>; mt19937 rng(chrono::steady_clock::now().time_since_epoch().count()); int n,k; vector<pair<int,int>>G[maxn]; int sz[maxn]; int ok[maxn]; int h[maxn]; int h1[maxn]; map<int,int>p; int ans=1e9; void dfs(int u,int pa){ sz[u]=1; for(auto v:G[u]){ if(v.fi==pa || ok[v.fi]==1)continue; dfs(v.fi,u); sz[u]+=sz[v.fi]; } } int fin(int u,int pa,int siz){ for(auto v:G[u]){ if(v.fi==pa || ok[v.fi]==1)continue; if(sz[v.fi]>siz/2)return fin(v.fi,u,siz); } return u; } void dfs1(int u,int pa){ if(h[u]==k){ ans=min(ans,h1[u]); } if(p.find(k-h[u])!=p.end()){ ans=min(ans,p[k-h[u]]+h1[u]); } for(auto v:G[u]){ if(v.fi==pa || ok[v.fi]==1)continue; h[v.fi]=h[u]+v.se; h1[v.fi]=h[u]+1; dfs1(v.fi,u); } } void dfs2(int u,int pa){ if(p[h[u]]==0){ p[h[u]]=h1[u]; } else{ p[h[u]]=min(p[h[u]],h1[u]); } for(auto v:G[u]){ if(v.fi==pa|| ok[v.fi]==1)continue; dfs2(v.fi,u); } } void build(int u,int pa){ dfs(u,pa); int cen=fin(u,pa,sz[u]); ok[cen]=1; h[cen]=0; h1[cen]=0; p.clear(); for(int i=0;i<G[cen].size();i++){ int v=G[cen][i].fi; if(v==pa || ok[v]==1)continue; h[v]=G[cen][i].se; h1[v]=1; dfs1(v,cen); dfs2(v,cen); } p.clear(); h[cen]=0; h1[cen]=0; for(int i=G[cen].size()-1;i>=0;i--){ int v=G[cen][i].fi; if(v==pa || ok[v]==1)continue; h[v]=G[cen][i].se; h1[v]=1; dfs1(v,cen); dfs2(v,cen); } for(auto v:G[cen]){ if(v.fi==pa || ok[v.fi]==1)continue; build(v.fi,cen); } } signed main() { cin.tie(0),cout.tie(0)->sync_with_stdio(0); //freopen(task".inp" , "r" , stdin); //freopen(task".out" , "w" , stdout); cin>>n>>k; for(int i=1;i<n;i++){ int u,v,w; cin>>u>>v>>w; u++; v++; G[u].pb({v,w}); G[v].pb({u,w}); } build(1,-1); if(ans==1e9+5){ cout<<-1; } else{ cout<<ans; } return 0; }

Compilation message (stderr)

race.cpp: In function 'void build(long long int, long long int)':
race.cpp:89:15: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   89 |  for(int i=0;i<G[cen].size();i++){
      |              ~^~~~~~~~~~~~~~
/usr/bin/ld: /tmp/ccOI8gBC.o: in function `main':
race.cpp:(.text.startup+0x0): multiple definition of `main'; /tmp/ccw4IQuE.o:grader.cpp:(.text.startup+0x0): first defined here
/usr/bin/ld: /tmp/ccw4IQuE.o: in function `main':
grader.cpp:(.text.startup+0x28): undefined reference to `best_path(int, int, int (*) [2], int*)'
collect2: error: ld returned 1 exit status