#include "dungeon2.h"
#include <bits/stdc++.h>
using namespace std;
static const int MAXN = 105;
static int par[MAXN], dep[MAXN];
static vector<int> ed[MAXN];
static int N;
static int dis[MAXN][MAXN];
static int cnt[MAXN];
int anc(int x, int d) {
while(dep[x] > d) x = par[x];
return x;
}
void dfs(int x) {
int k = NumberOfRoads();
int l = LastRoad();
//printf("x = %d, k = %d, l = %d, par = %d, dep = %d\n", x, k, l, par[x], dep[x]);
for(int i = 1; i <= k; i++) if(i != l) {
Move(i, dep[x]);
int c = Color();
//printf("c = %d\n", c);
if(c == 1) {
N++;
ed[x].push_back(N);
ed[N].push_back(x);
par[N] = x;
dep[N] = dep[x] + 1;
dfs(N);
}
else {
Move(LastRoad(), c);
if(c < dep[x]) {
int y = anc(x, c);
//printf("x = %d, y = %d\n", x, y);
ed[x].push_back(y);
ed[y].push_back(x);
}
}
}
if(l != -1) Move(l, dep[x]);
}
void Inspect(int R) {
dep[1] = 2;
N = 1;
dfs(1);
/*
for(int i = 1; i <= N; i++) {
printf("ed[%d] = [", i);
for(auto a : ed[i]) printf("%d ", a);
printf("]\n");
}
*/
for(int i = 1; i <= N; i++) for(int j = 1; j <= N; j++) dis[i][j] = i == j ? 0 : N;
for(int i = 1; i <= N; i++) for(auto a : ed[i]) dis[i][a] = 1;
for(int k = 1; k <= N; k++) for(int i = 1; i <= N; i++) for(int j = 1; j <= N; j++)
if(dis[i][k] + dis[k][j] < dis[i][j]) dis[i][j] = dis[i][k] + dis[k][j];
//for(int i = 1; i <= N; i++) for(int j = 1; j <= N; j++) printf("dis[%d][%d] = %d\n", i, j, dis[i][j]);
for(int i = 1; i <= N; i++) for(int j = i + 1; j <= N; j++) cnt[dis[i][j]]++;
for(int i = 1; i <= R; i++) Answer(i, cnt[i]);
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
504 KB |
Output is correct |
2 |
Correct |
2 ms |
376 KB |
Output is correct |
3 |
Correct |
2 ms |
504 KB |
Output is correct |
4 |
Correct |
2 ms |
504 KB |
Output is correct |
5 |
Correct |
3 ms |
504 KB |
Output is correct |
6 |
Correct |
2 ms |
376 KB |
Output is correct |
7 |
Correct |
2 ms |
376 KB |
Output is correct |
8 |
Correct |
2 ms |
376 KB |
Output is correct |
9 |
Correct |
2 ms |
376 KB |
Output is correct |
10 |
Correct |
2 ms |
504 KB |
Output is correct |
11 |
Correct |
2 ms |
504 KB |
Output is correct |
12 |
Correct |
2 ms |
504 KB |
Output is correct |
13 |
Correct |
2 ms |
504 KB |
Output is correct |
14 |
Correct |
3 ms |
504 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
2 ms |
376 KB |
Wrong Answer [6] |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
3 ms |
760 KB |
Wrong Answer [6] |
2 |
Halted |
0 ms |
0 KB |
- |