Submission #859140

#TimeUsernameProblemLanguageResultExecution timeMemory
859140VanioSpeedrun (RMI21_speedrun)C++17
0 / 100
86 ms1900 KiB
#include<bits/stdc++.h> #include "speedrun.h" using namespace std; int n,f[1001],pr; vector<int> v[1001]; void encode(int p, int k, int indx){ int i=indx; while(k>0){ setHint(p,i,k%2); k/=2; i++; } } void dfsen(int k, int par){ if(f[pr]==2){ encode(pr,k,1); encode(pr,par,11); } if(v[k].size()==0){f[k]=2; pr=k; return;} f[k]=1; pr=k; encode(k,par,1); encode(k,v[k][0],11); for(int i=0;i<v[k].size();i++){ if(f[v[k][i]]==0) dfsen(v[k][i],k); } } void assignHints(int subtask, int N, int a[], int b[]){ n=N; int i; for(i=1;i<n;i++){ v[a[i]].push_back(b[i]); v[b[i]].push_back(a[i]); } setHintLen(20); dfsen(1,0); } int decode(int indx){ int s=0,t=512,i; for(i=indx;i>indx-10;i--){ s+=getHint(i)*t; t/=2; } return s; } void dfssr(int k,int par){ if(par!=decode(10)){ v[decode(20)].push_back(decode(10)); return; } v[k].push_back(decode(20)); for(int i=0;i<v[k].size();i++){ goTo(v[k][i]); dfssr(v[k][i],k); } if(par==0) return; goTo(par); } void speedrun(int subtask, int N, int start){ n=N; int i,t1,t2; t1=decode(10); t2=decode(20); if(t1==0 && t2==0){ for(i=1;i<=n;i++){ if(i==start) continue; if(goTo(i)) break; } } else if(t1!=0){ if(!goTo(t1)){ for(i=1;i<=n;i++){ if(i==start || i==t1) continue; if(goTo(i)) break; } } } while(t1=decode(10)) goTo(t1); dfssr(1,0); }

Compilation message (stderr)

speedrun.cpp: In function 'void dfsen(int, int)':
speedrun.cpp:27:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   27 |     for(int i=0;i<v[k].size();i++){
      |                 ~^~~~~~~~~~~~
speedrun.cpp: In function 'void dfssr(int, int)':
speedrun.cpp:59:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   59 |     for(int i=0;i<v[k].size();i++){
      |                 ~^~~~~~~~~~~~
speedrun.cpp: In function 'void speedrun(int, int, int)':
speedrun.cpp:86:13: warning: suggest parentheses around assignment used as truth value [-Wparentheses]
   86 |     while(t1=decode(10)) goTo(t1);
      |           ~~^~~~~~~~~~~
#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...