# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
672782 | tbzard | Packing Biscuits (IOI20_biscuits) | C++14 | 1100 ms | 84992 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
long long count_tastiness(long long x, vector<long long> a){
long double b = 1, sum = 0;
set<long double> ans;
ans.insert(0);
for(int i=0;i<a.size();i++){
sum += b*a[i];
while(1){
vector<long double> add;
set<long double>::iterator it = ans.upper_bound(sum/x);
it--;
for(;;it--){
long double val = *it+(1ll<<i);
if(sum/x >= val){
if(ans.find(val) != ans.end()) break;
add.push_back(val);
}
if(it == ans.begin()) break;
}
for(int j=0;j<add.size();j++){
ans.insert(add[j]);
}
if(add.empty()) break;
}
b *= 2;
}
return (long long)ans.size();
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |