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 "speedrun.h"
#include <bits/stdc++.h>
using namespace std;
bool vis[1007];
int parset[1007];
vector<int> adj[1007];
vector<int> dorder[1007];
int n;
void dfs(int x, int p, int d){
vis[x] = 1;
parset[x] = p;
dorder[d].push_back(x);
for (auto y : adj[x]){
if (!vis[y]){
dfs(y, x, d+1);
}
}
}
void assignHints(int subtask, int N, int A[], int B[]) { /* your solution here */
setHintLen(20);
for (int x = 1; x < N; x++){
adj[A[x]].push_back(B[x]);
adj[B[x]].push_back(A[x]);
}
//let root be 1 always
dfs(1, 0, 0);
vector<int> inorder;
for (int x = 0; x <= N; x++){
for (auto y : dorder[x]){
inorder.push_back(y);
}
}
//data 1 is par
//data 2 is next
int next[N+1];
for (int x = 0; x < N-1; x++){
next[ inorder[x] ] = inorder[x+1];
}
next[inorder[N-1]] = inorder[0];
//encryption
for (int x = 1; x <= N; x++){
for (int z = 0; z <= 9; z++){
if (parset[x] & (1<<z)){
setHint(x, z+1, 1);
}
}
for (int z = 0; z <= 9; z++){
if (next[x] & (1<<z)){
setHint(x, z+11, 1);
}
}
}
return;
}
int par[1007];
int nextt[1007];
int cur;
#define WEIRD -23145
int nn;
inline void setDetails(){
if (nextt[cur] != WEIRD) return;
par[cur] = 0; nextt[cur] = 0;
for (int z = 0; z <= 9; z++){
if (getHint(z+1)){
par[cur] += (1<<z);
}
}
for (int z = 0; z <= 9; z++){
if (getHint(z+11)){
nextt[cur] += (1<<z);
}
}
}
inline void assertGoTo(int x){
goTo(x);
}
inline void returnToRoot(){
setDetails();
int steps = 0;
while (cur != 1){
assertGoTo(par[cur]);
cur = par[cur];
setDetails();
assert(cur >= 1 && cur <= nn);
}
}
vector<int> moves[1007];
inline void trace(int x){
unordered_map<int, int> nodes;
for (int y = 0; y < moves[x].size(); y++){
nodes[moves[x][y]] = y+1;
}
nodes[1] = 0;
while (nodes.count(cur) == 0){
goTo(par[cur]);
cur = par[cur];
}
int idx = nodes[cur];
for (int z = idx; z < moves[x].size(); z++){
goTo(moves[x][z]);
cur = moves[x][z];
}
return;
}
void speedrun(int subtask, int N, int start) { /* your solution here */
cur = start;
nn = N;
for (int x = 0; x < 1007; x++) par[x] = WEIRD;
for (int x = 0; x < 1007; x++) nextt[x] = WEIRD;
returnToRoot();
vector<int> inorder;
inorder.push_back(1);
int ptr = 0;
int nodeCount = 1;
for (int z = 0; z < N-1; z++){
int nextnode = nextt[inorder.back()];
if (nextnode == 0) break;
trace(inorder[ptr]);
while (!goTo(nextnode)){
ptr++;
trace(inorder[ptr]);
}
nodeCount++;
inorder.push_back(nextnode);
cur = nextnode;
moves[cur] = moves[inorder[ptr]];
moves[cur].push_back(cur);
setDetails();
}
}
Compilation message (stderr)
speedrun.cpp: In function 'void returnToRoot()':
speedrun.cpp:101:6: warning: unused variable 'steps' [-Wunused-variable]
101 | int steps = 0;
| ^~~~~
speedrun.cpp: In function 'void trace(int)':
speedrun.cpp:115:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
115 | for (int y = 0; y < moves[x].size(); y++){
| ~~^~~~~~~~~~~~~~~~~
speedrun.cpp:126:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
126 | for (int z = idx; z < moves[x].size(); z++){
| ~~^~~~~~~~~~~~~~~~~
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |