제출 #1078785

#제출 시각아이디문제언어결과실행 시간메모리
1078785LittleOrange죄수들의 도전 (IOI22_prison)C++17
53 / 100
11 ms1372 KiB
#include "prison.h" #include <vector> #include<bits/stdc++.h> using namespace std; using ll = int; const ll m = 2; ll g(ll x, ll lv){ //cerr << "g " << x << " " << lv; while(lv-->0) x/=m; //cerr << " = " << x%m << "\n"; return x%m; } ll cal(ll x){ ll r = 0; while(x){ r++; x/=m; } return r; } std::vector<std::vector<int>> devise_strategy(int N) { ll n = N; ll lvl = cal(n); vector<vector<ll>> ret; vector<ll> mp; { vector<ll> a(n+1,0); for(ll i = 1;i<=n;i++) a[i] = g(i,lvl)+1; ret.push_back(a); } for(ll j = 0;j<=lvl;j++){ ll h = lvl-j; ll tp = j&1^1; for(ll x = 0;x<m;x++){ vector<ll> a(n+1,tp); for(ll i = 1;i<=n;i++){ ll v = g(i,h); if (v<x) a[i] = -1-tp; else if (v>x) a[i] = -2+tp; else a[i] = g(i,h-1)+(j+1)*m+1; } ret.push_back(a); } } //ofstream stra("str.txt"); //stra << ret.size() << "\n"; ll x = ret.size()-1; for(auto &o : ret){ for(ll &i : o){ if (i<-2||i>x) i = x; } //for(ll i = 0;i<=n;i++) stra << o[i] << " \n"[i==n]; } return ret; }

컴파일 시 표준 에러 (stderr) 메시지

prison.cpp: In function 'std::vector<std::vector<int> > devise_strategy(int)':
prison.cpp:34:14: warning: suggest parentheses around arithmetic in operand of '^' [-Wparentheses]
   34 |     ll tp = j&1^1;
      |             ~^~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...