# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
705825 | bin9638 | 도시들 (IOI15_towns) | C++17 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define fs first
#define sc second
#define N 210
#define pb push_back
#define ii pair<ll,ll>
int dis[N][N],c[N][N];
#ifdef SKY
int getDistance(int i, int j)
{
return dis[i][j];
}
#endif // SKY
int hubDistance(int n, int sub)
{
for(int i=1;i<n;i++)
c[0][i]=c[i][0]=getDistance(0,i);
int S=1;
for(int i=1;i<n;i++)
if(c[0][i]>c[0][S])
S=i;
// da tinh 0
for(int i=1;i<n;i++)
if(i!=S)
c[S][i]=c[i][S]=getDistance(S,i);
int T=0;
for(int i=0;i<n;i++)
if(c[S][i]>c[S][T])
T=i;
//cout<<S<<" "<<T<<endl;
int L=(dis[S][T]+dis[0][S]+dis[0][T])/2-dis[0][T],
R=(dis[S][T]+dis[0][S]+dis[0][T])/2-dis[0][S],
K=(dis[S][T]+dis[0][S]+dis[0][T])/2-dis[S][T];
int res=max(L,R);
// cout<<L<<" "<<R<<" "<<K<<endl;
for(int i=1;i<n;i++)
if(!(dis[S][i]-dis[0][i]==L-K))
//if(i==0)
{
int length=(dis[S][i]+dis[0][i]+dis[0][S])/2-dis[0][i];
//cout<<length<<endl;
res=min(res,max(length,dis[S][T]-length));
}
return res;
}
#ifdef SKY
int main()
{
freopen("A.inp","r",stdin);
freopen("A.out","w",stdout);
int n;
int q;
cin>>q;
while(q--)
{
int n,sub;
cin>>sub>>n;
//cout<<n<<endl;
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
cin>>dis[i][j];
cout<<hubDistance(n, sub)<<endl;
}
return 0;
}
#endif // SKY