Submission #370076

#TimeUsernameProblemLanguageResultExecution timeMemory
370076MilosMilutinovicPacking Biscuits (IOI20_biscuits)C++14
0 / 100
1184 ms1727116 KiB
#include "biscuits.h"
#include <bits/stdc++.h>
using namespace std;

#define ll long long

const int N=62;
map<ll, ll> dp;
ll pref[N], x;

ll Solve(ll n) {
	if(n<=0)
		return 0LL;
	if(n==1)
		return 1LL;
	if(dp.find(n)!=dp.end())
		return dp[n];
	ll i=__lg(n-1);
	ll ans=Solve((ll)(1<<i))+Solve(min(n,pref[i]/x+1)-(ll)(1<<i));
	return dp[n]=ans;
}

ll count_tastiness(ll X, vector<ll> a) {
	x=X;
	dp.clear();
	for(int i=0; i<(int)a.size(); ++i)
		pref[i]=(i>0?pref[i-1]:0LL)+a[i]*(ll)(1<<i);
	for(int i=(int)a.size(); i<=61; ++i)
		pref[i]=pref[i-1];
	return Solve(pref[61]);
}
#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...