제출 #622922

#제출 시각아이디문제언어결과실행 시간메모리
622922JeanBombeur비스킷 담기 (IOI20_biscuits)C++17
100 / 100
14 ms1308 KiB
#include "biscuits.h" #include <iostream> #include <cstdio> using namespace std; // <|°_°|> // M. Broccoli const int NB_BITS = 60; long long DP[NB_BITS + 1]; long long count_tastiness(long long nbPacks, vector <long long> Biscuits) { Biscuits.resize(NB_BITS); DP[0] = 1; for (int i = 1; i < NB_BITS; i ++) { Biscuits[i] = (Biscuits[i] << i) + Biscuits[i - 1]; } for (int i = 0; i < NB_BITS; i ++) { DP[i + 1] = 1; long long sum = Biscuits[i]; for (int j = i; j >= 0; j --) { sum = min(sum, Biscuits[j]); if (nbPacks <= (sum >> j)) DP[i + 1] += DP[j], sum -= (nbPacks << j); } } return DP[NB_BITS]; }
#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...