Submission #354333

#TimeUsernameProblemLanguageResultExecution timeMemory
354333David_MCave (IOI13_cave)C++14
100 / 100
300 ms640 KiB
#include "cave.h"
#include <bits/stdc++.h>
using namespace std;
int c[5003],f[5003],a[5003],i,j,x,l,r,m;
void A(int R){for(;R>=l;R--)c[R]^=!f[R];}
int T(){return(tryCombination(c)+9999)%9999<=i;}
void exploreCave(int N){
    for(;i<N;i++){
		l=0,r=N-1;
    	if(T())A(r);
    	while(l<r){m=l+r>>1;A(m);if(T())r=m,A(m);else l=m+1;}
		a[l]=i,f[l]=1;
	}answer(c,a);
}

Compilation message (stderr)

cave.cpp: In function 'void exploreCave(int)':
cave.cpp:11:20: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   11 |      while(l<r){m=l+r>>1;A(m);if(T())r=m,A(m);else l=m+1;}
      |                   ~^~
#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...