Submission #923342

# Submission time Handle Problem Language Result Execution time Memory
923342 2024-02-07T06:44:37 Z shoryu386 Speedrun (RMI21_speedrun) C++17
60 / 100
3500 ms 3880 KB
#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;

void setDetails(){
	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);
		}
	}
}

void assertGoTo(int x){
	assert(goTo(x));
}

void returnToRoot(){
	setDetails();
	if (cur == 1){
		return;
	}
	assertGoTo(par[cur]);
	
	cur = par[cur];
	returnToRoot();
}

vector<int> moves[1007];
void trace(int x){
	returnToRoot();
	
	for (auto z : moves[x]){
		assertGoTo(z);
		cur = z;
	}
	return;
}

void speedrun(int subtask, int N, int start) { /* your solution here */
	cur = start;
	
	returnToRoot();
	vector<int> inorder;
	inorder.push_back(1);
	
	int ptr = 0;
	int nodeCount = 1;
	
	while (nodeCount < N){
		assert(ptr < inorder.size());
		int nextnode = nextt[inorder.back()];
		
		if (nextnode == 0) break;
		
		trace(inorder[ptr]);
		if (goTo(nextnode)){
			nodeCount++;
			inorder.push_back(nextnode);
			
			cur = nextnode;
			
			moves[cur] = moves[inorder[ptr]];
			moves[cur].push_back(cur);
			
			setDetails();
		}
		else{
			ptr++;
		}
	}
	
}

Compilation message

In file included from /usr/include/c++/10/cassert:44,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:33,
                 from speedrun.cpp:3:
speedrun.cpp: In function 'void speedrun(int, int, int)':
speedrun.cpp:125:14: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  125 |   assert(ptr < inorder.size());
      |          ~~~~^~~~~~~~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 174 ms 1900 KB Output is correct
2 Execution timed out 3525 ms 3880 KB Time limit exceeded
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 59 ms 2136 KB Output is correct
2 Correct 50 ms 1416 KB Output is correct
# Verdict Execution time Memory Grader output
1 Execution timed out 3532 ms 3256 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 691 ms 2012 KB Output is correct
2 Correct 238 ms 1904 KB Output is correct
3 Correct 93 ms 1448 KB Output is correct
4 Correct 3151 ms 3356 KB Output is correct
5 Correct 534 ms 2120 KB Output is correct
6 Correct 86 ms 1700 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 535 ms 2328 KB Output is correct
2 Correct 313 ms 2224 KB Output is correct
3 Correct 120 ms 2416 KB Output is correct
4 Correct 2779 ms 3456 KB Output is correct
5 Correct 118 ms 1892 KB Output is correct
6 Correct 615 ms 2356 KB Output is correct
7 Correct 60 ms 1620 KB Output is correct