Submission #644846

#TimeUsernameProblemLanguageResultExecution timeMemory
644846PanTkdSpeedrun (RMI21_speedrun)C++17
0 / 100
431 ms800 KiB
#include "speedrun.h" #include <iostream> #include <algorithm> #include <bitset> #include <complex> #include <deque> #include <fstream> #include <iomanip> #include <iterator> #include <limits> #include <list> #include <cstring> #include <map> #include <queue> #include <set> #include <stack> #include <string> #include <vector> #include <unordered_map> using namespace std; typedef int ll; typedef vector<ll> vi; typedef pair<ll,ll> ii; #ifdef px #define p(x) cerr<<#x<<' '<<x<<endl; #else #define p(x) {} #endif #define F first #define S second #define sz size #define ls s,m,idx<<1 #define rs m+1,e,idx<<1|1 const ll MOD=ll(1e9)+7; const ll MAXN=2*ll(1e6); ll freq[20001]; ll arxi; vector<vi> Adj; vi Par,Son; void dfs(ll s,ll p=-1){ for(auto x:Adj[s]){ if(x!=p){ Par[x]=s; Son[s]=x; dfs(x,s); } } } void assignHints(int subtask, int N, int A[], int B[]) { setHintLen(20); Adj.assign(N+1,vi()); Par.assign(N+1,0); Son.assign(N+1,0); for(ll i=1;i<N;i++){ freq[A[i]]++; freq[B[i]]++; Adj[A[i]].push_back(B[i]); Adj[B[i]].push_back(A[i]); } for(ll i=1;i<=N;i++){ if(freq[i]==1){ arxi=i; break; } } p(arxi); Par[arxi]=arxi; Son[arxi]=arxi; ll curr=arxi; dfs(arxi,arxi); for(ll i=1;i<=N;i++){ ll son=0,par=0; for(ll j=0;j<10;j++){ if((1<<j)&Son[i]){ setHint(i,j+1,1); son|=(1<<j); }else{ setHint(i,j+1,0); } if((1<<j)&Par[i]){ setHint(i,j+11,1); par|=(1<<j); }else{ setHint(i,j+11,0); } } //cout<<i<<"->"<<son<<"<-"<<par<<endl; //cout<<i<<"->"<<Son[i]<<"<-"<<Par[i]<<endl; } } ll l; void speedrun(int subtask, int N, int start) { /* your solution here */ if(start==arxi){ ll curr=start; for(ll i=1;i<N;i++){ ll x=0; for(ll j=1;j<=10;j++){ if(getHint(j))x|=(1<<(j-1)); } curr=x; goTo(curr); } } else{ ll curr=start; while(curr!=arxi){ ll x=0; for(ll j=11;j<=20;j++){ if(getHint(j))x|=(1<<(j-11)); } curr=x; goTo(curr); } for(ll i=1;i<N;i++){ ll x=0; for(ll j=1;j<=10;j++){ if(getHint(j))x|=(1<<(j-1)); } curr=x; goTo(curr); } } }

Compilation message (stderr)

speedrun.cpp: In function 'void assignHints(int, int, int*, int*)':
speedrun.cpp:73:8: warning: unused variable 'curr' [-Wunused-variable]
   73 |     ll curr=arxi;
      |        ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...