# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
15889 | ggoh | Dreaming (IOI13_dreaming) | C++98 | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "dreaming.h"
#include<cstdio>
#include<vector>
#include<algorithm>
struct AA{
int to,cost;
};
std::vector<AA>G[100002];
int ans,i,m,t,st[100002],dis[100002],pos,len,K;
bool v[2][100002];
void dfs(int x,int p)
{
for(int j=0;j<G[x].size();j++)
{
AA u=G[x][j];
if(!v[p][u.to])
{
dis[u.to]=dis[x]+u.cost;
if(m<=dis[u.to])
{
pos=u.to;m=dis[u.to];
}
v[p][u.to]=1;
dfs(u.to);
}
}
}
int travelTime(int N,int M,int L,int A[],int B[],int T[])
{
for(i=0;i<M;i++)
{
G[A[i]+1].push_back({B[i]+1,T[i]});
G[B[i]+1].push_back({A[i]+1,T[i]});
}
for(i=1;i<=N;i++)
{
if(!v[0][i])
{
v[0][i]=1;
m=0;pos=i;dis[i]=0;
dfs(i,0);
m=0;v[1][pos]=1;dis[pos]=0;
dfs2(pos,1);
len=std::max(len,m);
K=m;st[t]=m;
while(dis[pos])
{
for(int k=0;k<G[pos].size();k++)
{
if(dis[G[pos][k].to]+G[pos][k].cost==dis[pos])
{
K-=G[pos][k].cost;
pos=G[pos][k].to;
break;
}
}
st[t]=std::min(st[t],std::max(K,m-K));
}
t++;
}
}
std::sort(st,st+t);
ans=len;
if(t>1)ans=std::max(st[t-1]+st[t-2]+L,ans);
if(t>2)ans=std::max(ans,st[t-2]+2*L+st[t-3]);
return ans;
}