# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
34550 | Extazy | Computer Network (BOI14_network) | C++14 | 116 ms | 6016 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 <bits/stdc++.h>
#include "network.h"
#define endl '\n'
using namespace std;
const int N = 1024;
int n,a,b;
int da[N],db[N];
int min_dist;
int shortest,path[N],path_sz;
/*void travelTo(int x) {
}
int ping(int a, int b) {
}*/
int ask(int a, int b) {
if(a==b) return 0;
return 1+ping(a,b);
}
bool cmp(int a, int b) {
return da[a]<da[b];
}
void findRoute(int N, int A, int B) {
int i;
n=N;
a=A;
b=B;
shortest=ask(a,b);
da[a]=0;
da[b]=shortest;
db[a]=shortest;
db[b]=0;
path_sz=0;
for(i=1;i<=n;i++) if(i!=A && i!=B) {
da[i]=ask(a,i);
db[i]=ask(b,i);
if(da[i]+db[i]==shortest) path[++path_sz]=i;
}
bool f=false;
for(i=2;i<=path_sz;i++) if(da[i]+db[i]==da[i-1]+db[i-1]) f=true;
if(f==false) { //Subtask 1
sort(path+1,path+1+path_sz,cmp);
for(i=1;i<=path_sz;i++) travelTo(path[i]);
travelTo(b);
}
}
/*int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
return 0;
}*/
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |