Submission #886844

#TimeUsernameProblemLanguageResultExecution timeMemory
886844sochoSnake Escaping (JOI18_snake_escaping)C++14
22 / 100
800 ms65536 KiB
#include <bits/stdc++.h> using namespace std; typedef long long LL; typedef double D; typedef vector<int> VI; typedef set<int> SI; typedef map<int, int> MII; typedef pair<int, int> PII; #define A first #define B second #define SZ(x) int(x.size()) #define PB push_back #define FR(i, a, b) for (int i = (a); i < (b); i++) #define FOR(i, n) FR(i, 0, n) #define RF(i, a, b) for (int i = (a); i >= (b); i--) #define FRA(a, x) for (auto a: (x)) template <typename T> inline void set_min(T &a, T b) {if(b < a) a = b;} template <typename T> inline void set_max(T &a, T b) {if(b > a) a = b;} int n, q; string s; const int MXN = 20; int dp[MXN][1<<MXN]; int dp2[MXN][1<<MXN]; int val[1<<MXN]; VI ms; signed main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); cin >> n >> q; cin >> s; FOR(i, 1<<n) { val[i] = (s[i] - '0'); } FOR(b, n) { FOR(i, 1<<n) { if (b == 0) { dp[b][i] = ((i & (1 << b)) > 0 ? val[i] + val[i ^ (1<<b)] : val[i]); dp2[b][i] = ((i & (1 << b)) == 0 ? val[i] + val[i ^ (1<<b)] : val[i]); } else { dp[b][i] = ((i & (1 << b)) > 0 ? dp[b-1][i] + dp[b-1][i ^ (1<<b)] : dp[b-1][i]); dp2[b][i] = ((i & (1 << b)) == 0 ? dp2[b-1][i] + dp2[b-1][i ^ (1<<b)] : dp2[b-1][i]); } } } FOR(_, q) { string s; cin >> s; reverse(s.begin(), s.end()); int n0 = 0, n1 = 0, nq = 0; FRA(x, s) { if (x == '?') nq++; else if (x == '0') n0++; else n1++; } int ans = 0; if (nq <= 6) { // just add over the bitmasks int main = 0; FOR(i, n) { if (s[i] == '?') ms.PB(i); else if (s[i] == '1') main += (1 << i); } FOR(i, 1<<nq) { int p = main; FOR(j, nq) { if (i & (1 << j)) p += (1 << ms[j]); } ans += val[p]; } } else if (n0 <= 6) { // 0011?? // super(001100) // -super(011100) // -super(101100) // +super(111100) int main = 0; FOR(i, n) { if (s[i] == '0') ms.PB(i); else if (s[i] == '1') main += (1 << i); } FOR(i, 1<<n0) { int p = main; FOR(j, n0) { if (i & (1 << j)) { p += (1 << ms[j]); } } if (__builtin_popcount(i) % 2 == 0) ans += dp2[n-1][p]; else ans -= dp2[n-1][p]; } } else { // n1 <= 6 // 0011?? // sub(001111) // -sub(001011) // -sub(000111) // +sub(000011) int main = 0; FOR(i, n) { if (s[i] == '1') ms.PB(i); else if (s[i] == '?') main += (1 << i); } FOR(i, 1<<n1) { int p = main; FOR(j, n1) { if (i & (1 << j)) p += (1 << ms[j]); } if ((n1 - __builtin_popcount(i)) % 2 == 0) ans += dp[n-1][p]; else ans -= dp[n-1][p]; } } cout << ans << '\n'; ms.clear(); } }
#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...