이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "biscuits.h"
#include <bits/stdc++.h>
using namespace std;
using ll = long long int;
long long count_tastiness(long long x, std::vector<long long> a) {
int k = a.size();
vector<ll> dp(k);
vector<ll> pdp(k+1);
vector<ll> psum(k+1);
for(int i=1;i<=k;i++){
psum[i] = psum[i-1] + a[i-1] * (1ll<<(i-1));
}
for(int i=0;i<k;i++){
dp[i] = ((psum[i+1] / (1ll<<i) / x) != 0);
ll sum = psum[i+1] - (1ll<<i) * x;
ll mx = sum / x;
mx = min(mx, (1ll<<i) - 1);
for(int j=i-1,s=0;j>=0;--j){
if(mx & (1ll<<j)){
dp[i] += pdp[j] + s;
sum = min(psum[j+1], sum);
sum -= (1ll<<j) * x;
mx = sum / x;
mx = min(mx, (1ll<<j) - 1);
s |= 1;
}
}
pdp[i+1] = pdp[i] + dp[i];
}
//for(auto &x : dp) cout<<x<<" ";
//cout<<"\n";
return pdp[k] + 1;
}
# | 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... |