Submission #1019190

#TimeUsernameProblemLanguageResultExecution timeMemory
1019190j_vdd16Packing Biscuits (IOI20_biscuits)C++17
9 / 100
1138 ms1071032 KiB
#include <algorithm> #include <bitset> #include <cstdint> #include <cstring> #include <iostream> #include <limits.h> #include <math.h> #include <map> #include <numeric> #include <queue> #include <set> #include <stack> #include <string> #include <vector> #define int long long #define ll long long #define loop(X, N) for(int X = 0; X < (N); X++) #define all(V) V.begin(), V.end() #define rall(V) V.rbegin(), V.rend() using namespace std; typedef vector<int> vi; typedef vector<vi> vvi; typedef pair<int, int> ii; typedef vector<ii> vii; typedef vector<vector<ii>> vvii; typedef vector<bool> vb; typedef vector<vector<bool>> vvb; int count_tastiness(int x, vi a) { constexpr int N = 61; while (a.size() < N) a.push_back(0); int sum = 0; loop(i, N) sum += a[i] * (1LL << i); int result = sum + 1; vi counts(sum + 1, 0); vb isValid(sum + 1, true); loop(bit, N) { for (int y = 0; y <= sum; y++) { if (!isValid[y]) continue; int& count = counts[y]; count /= 2; count += a[bit]; if ((y & (1LL << bit)) == 0) continue; if (count < x) { result--; isValid[y] = false; continue; } count -= x; } } return result; }
#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...