Submission #587891

#TimeUsernameProblemLanguageResultExecution timeMemory
587891MrDebooDreaming (IOI13_dreaming)C++17
Compilation error
0 ms0 KiB
#include "dreaming.h" #include <bits/stdc++.h> using namespace std; multiset<int>st; vector<pair<int,int>>vct[100000]; vector<pair<int,int>>vec[100000]; int fath[100000]; int val[100000]; int n,m,l,f,ans; int diam(int in){ deque<pair<int,int>>dq={{in,0}}; map<int,bool>vis; vis[in]=1; int x=0,y=0; while(dq.size()){ int a=dq.front().first,b=dq.front().second; dq.pop_front(); if(b>=y){ x=a; y=b; } for(auto &i:vct[a]){ if(!vis[i.first]){ vis[i.first]=1; dq.push_back({i.first,b+i.second}); } } } dq.push_back({x,0}); x=0;y=0; vis.clear(); while(dq.size()){ int a=dq.front().first,b=dq.front().second; dq.pop_front(); if(b>=y){ x=a; y=b; } for(auto &i:vct[a]){ if(!vis[i.first]){ vis[i.first]=1; dq.push_back({i.first,b+i.second}); } } } return y; } int dfs1(int in){ for(auto &i:vec[in])val[in]=max(val[in],dfs1(i.first)+i.second); return val[in]; } void dfs2(int in,int x){ f=min(f,max(x,val[in])); for(auto &i:vec[in])dfs2(i.first,x+i.second); } int travelTime(int N, int M, int L, int a[], int b[], int t[]){ n=N,m=M,l=L; for(int i=0;i<m;i++){ vct[a[i]].push_back({b[i],t[i]}); vct[b[i]].push_back({a[i],t[i]}); } deque<int>v; vector<int>vis(n); for(int i=0;i<n;i++){ if(vis[i])continue; vis[i]=1; vector<int>vc={i}; { deque<int>dq={i}; while(dq.size()){ int a=dq.front(); dq.pop_front(); for(auto &w:vct[a]){ if(!vis[w.first]){ vis[w.first]=1; vec[a].push_back(w); fath[w.first]=a; dq.push_back(w.first); vc.push_back(w.first); } } } } f=INT_MAX; ans=max(ans,diam(i)); if(vc.size()==1)f=0; else{ dfs1(i); f=min(f,val[i]); vector<pair<int,int>>V={{0,-1}}; for(auto &w:vec[i])V.push_back({w.second+val[w.first],w.first}); sort(V.begin(),V.end()); for(auto &w:vec[i]){ if(w.first==V.back().second)dfs2(w.first,V[V.size()-2].first+w.second); else dfs2(w.first,V.back().first+w.second); } } st.insert(f); } while(st.size()>1){ int a=*st.begin(); st.erase(st.begin()); int b=*(--st.end()); st.erase(--st.end()); ans=max(ans,a+b+l); st.insert(max(a+l,b)); } return ans; } int main(){ int n,m,l; cin>>n>>m>>l; int a[m],b[m],t[m]; for(auto &i:a)cin>>i; for(auto &i:b)cin>>i; for(auto &i:t)cin>>i; cout<<travelTime(n,m,l,a,b,t); }

Compilation message (stderr)

/usr/bin/ld: /tmp/ccw4IK4r.o: in function `main':
dreaming.cpp:(.text.startup+0x0): multiple definition of `main'; /tmp/ccv7Durs.o:grader.c:(.text.startup+0x0): first defined here
collect2: error: ld returned 1 exit status