Submission #304361

#TimeUsernameProblemLanguageResultExecution timeMemory
304361QAQAutoMatonPacking Biscuits (IOI20_biscuits)C++17
100 / 100
14 ms896 KiB
#include "biscuits.h" #include <algorithm> #include <vector> typedef long long ll; std::vector<long long> a; ll x; ll s[105],f[105]; bool chkmin(ll &a,ll b){return a>b?a=b,1:0;} ll dfs(int x,ll y){ chkmin(y,s[x]); if(!x){return std::min(y,s[x])+1;} if(y<s[x-1])return dfs(x-1,y); if(s[x-1]+(1ll<<x)<=y)return f[x-1]<<1; if(y>=(1ll<<x))return f[x-1]+dfs(x-1,y-(1ll<<x)); return f[x-1]; } long long count_tastiness(long long X, std::vector<long long> A) { while(A.size()<60)A.emplace_back(0); x=X;a=A; int k=a.size(); ll cur=0; for(int i=0;i<k;++i){ s[i]=std::min((cur+=a[i]<<i)/x,(1ll<<(i+1))-1); } f[0]=s[0]+1; for(int i=1;i<k;++i){ f[i]=dfs(i,(1ll<<(i+1))-1); } return f[k-1]; }
#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...