Submission #645872

#TimeUsernameProblemLanguageResultExecution timeMemory
645872prvocisloPacking Biscuits (IOI20_biscuits)C++17
0 / 100
353 ms852 KiB
#include <algorithm> #include <bitset> #include <cassert> #include <chrono> #include <cmath> #include <deque> #include <iomanip> #include <iostream> #include <map> #include <queue> #include <random> #include <set> #include <string> #include <vector> #include "biscuits.h" typedef long long ll; typedef long double ld; using namespace std; map<vector<ll>, ll> m; ll rek(ll x, vector<ll> a) { if (a.empty()) return 1; if (m.count(a)) return m[a]; ll val = a.back(); a.pop_back(); ll ans = rek(x, a) * (val / x + 1); ll mis = x - (val % x); for (int i = (int)a.size() - 1; i >= 0; i--) { if (mis > 2 * x) break; mis *= 2ll; ll k = min(a[i], mis); a[i] -= k; mis -= k; if (mis == 0) { while (a.size() > 1 && a[a.size() - 2] == 0) a.pop_back(); ans += rek(x, a); break; } } return m[a] = ans; } ll count_tastiness(ll x, vector<ll> a) { m.clear(); int n = a.size(); for (int i = 0; i + 1 < n; i++) { if (a[i] >= x) { ll k = (a[i] - x) / 2ll; a[i] -= 2 * k; a[i + 1] += k; } } return rek(x, a); }
#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...