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 "biscuits.h"
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define F first
#define S second
#define sz(x) (ll)x.size()
#define MID ((l+r)/2)
#define pb push_back
#define dbg(x) cout<<#x<<": "<<x<<endl;
#define dbg2(x,y) cout<<#x<<": "<<x<<" "<<#y<<": "<<y<<endl;
#define dbg3(x,y,z) cout<<#x<<": "<<x<<" "<<#y<<": "<<y<<" "<<#z<<": "<<z<<endl;
#define dbg4(x,y,z,w) cout<<#x<<": "<<x<<" "<<#y<<": "<<y<<" "<<#z<<": "<<z<<" "<<#w<<": "<<w<<endl;
typedef vector <ll> vi;
typedef pair<ll,ll> ii;
typedef vector <ii> vii;
#define M 100001
ll count_tastiness(ll x, vi a) {
ll n = sz(a);
vi tmp;
ll ans = 1;
for (ll y =1; y<=M; y++){ //y
tmp = a;
ll sum;
ll f = -1;
//dbg(y);
do{
f++;
sum = 0;
for (ll i = n-1; i>=0; i--){
if (tmp[i] == 0) continue;
ll val = (1<<i);
ll d = (y - sum) / val;
ll g = min(d, tmp[i]);
//dbg4(sum, val,d,g);
tmp[i] -= g;
sum += g * val;
if (sum == y) break;
}
//dbg(sum);
}while (sum == y);
if (f >= x) ans++;
//dbg2(f,ans);
//cout<<endl;
}
return ans;
}
# | 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... |