Submission #979276

# Submission time Handle Problem Language Result Execution time Memory
979276 2024-05-10T13:02:46 Z Zicrus Counting Mushrooms (IOI20_mushrooms) C++17
0 / 100
0 ms 344 KB
#include <bits/stdc++.h>
#include "mushrooms.h"
using namespace std;

typedef long long ll;

int kVal, kA, kB;

void get(vector<ll> &m, int a, int b) {
    ll sol = use_machine({kA, a, kB, b});
    m[a] = (sol >> 1) ^ kVal;
    m[b] = (sol & 1) ^ kVal;
}

int count_mushrooms(int n) {
    if (n == 0) return 0;
    if (n == 1) return 1;
    vector<ll> m(n, 0);
    m[0] = 1;
	ll sol01 = use_machine({0, 1});
    ll sol02;
    if (n <= 2) {
        if (sol01 == 0) m[1] = 1;
        goto end; // Hello
    }
    sol02 = use_machine({0, 2});
    if (sol01 == 0) m[1] = 1;
    if (sol02 == 0) m[2] = 1;
    if (sol01 == 0) {
        kVal = 1;
        kA = 0; kB = 1;
    }
    else if (sol02 == 0) {
        kVal = 1;
        kA = 0; kB = 2;
    }
    else {
        kVal = 0;
        kA = 1; kB = 2;
    }
    for (ll i = 3; i < n-1; i += 2) {
        get(m, i, i+1);
    }
    if (!(n & 1)) {
        get(m, n-2, n-1);
    }

end:
    ll res = 0;
    for (auto &e : m) {
        res += e;
    }
    return res;
}
# Verdict Execution time Memory Grader output
1 Correct 0 ms 344 KB Output is correct
2 Incorrect 0 ms 344 KB Duplicate value 2 in the query array.
3 Halted 0 ms 0 KB -