# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
300986 | zecookiez | Computer Network (BOI14_network) | C++17 | 144 ms | 11768 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>
using namespace std;
template<class C>constexpr int len(const C&c){return int(c.size());}
const int MAXN = 1001;
vector<int> dist[MAXN];
int memo[MAXN][MAXN];
int pong(int a, int b){
if(memo[a][b] != -1) return memo[a][b];
return memo[a][b] = memo[b][a] = ping(a, b);
}
void findRoute(int N, int a, int b){
memset(memo, -1, sizeof(memo));
int c = pong(a, b); dist[c].push_back(b);
for(int v, i = 1; i <= N; ++i){
if(i == a) continue;
v = pong(a, i);
if(v < c) dist[v].push_back(i);
}
int prev = a;
for(int x = 0; x < c; ++x){
for(int nxt : dist[x]){
if(pong(prev, nxt) == 0 && x + 1 + pong(nxt, b) == c){
travelTo(nxt); prev = nxt;
break;
}
}
}
travelTo(b);
}
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... |