Submission #1055590

#TimeUsernameProblemLanguageResultExecution timeMemory
1055590MrPavlitoCave (IOI13_cave)C++17
0 / 100
22 ms348 KiB
#include "cave.h" #include <bits/stdc++.h> //#define int long long #define pb push_back #define mp make_pair #define all(x) (x).begin(),(x).end() #define fi first #define sc second //#define endl "\n" #define pii pair<int,int> using namespace std; const int MAXN = 5e3+5; const int mod7 = 1e9+7; const long long inf = 1e18; void exploreCave(int N) { int n = N; int trenutnacomb[n]; int solved[n]; int rez[n]; for(int i=0; i<n; i++)trenutnacomb[i] = 0, solved[i] = 0, rez[i] = 0; for(int i=0; i<n; i++) { for(int j=0; j<n; j++)trenutnacomb[j] = solved[j]; int t = tryCombination(trenutnacomb); int l = 0; int r = n-1; while(l<r) { int mid = l+r >> 1; for(int j=l; j<= mid; j++)if(!solved[j])trenutnacomb[j] ^= 1; int p = tryCombination(trenutnacomb); bool pomoc; if(p == i && t == i)pomoc = true; else if(p != i && t == i)pomoc = false; else if(p == i && t !=i) pomoc = false; else pomoc = true; if(!pomoc)r = mid; else l = mid+1; t = p; } solved[l] = i; rez[l] = trenutnacomb[l]; if(t == i)rez[l] = (trenutnacomb[l]^1); } answer(rez, solved); }

Compilation message (stderr)

cave.cpp: In function 'void exploreCave(int)':
cave.cpp:33:24: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   33 |             int mid = l+r >> 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...