Submission #1283973

#TimeUsernameProblemLanguageResultExecution timeMemory
1283973faricaPacking Biscuits (IOI20_biscuits)C++20
0 / 100
1103 ms181400 KiB
#include "biscuits.h"
#include <bits/stdc++.h>

using namespace std;
using ll = long long;

long long count_tastiness(long long x, std::vector<long long> a) {
  int n = (int)a.size();
  set<ll>S;
  vector<ll>s(60, 0);
  for(int i=0; i<60; ++i) {
    if(i < n) s[i] = (1LL<<i) * a[i];
    if(i) s[i] += s[i-1];
  }
  S.insert(0);
  for(int i=0; i<60; ++i) {
    for(auto it = S.begin(); it != S.end(); ++it) {
      ll cur = (*it);
      if(s[i] >= (cur+(1LL<<i)) * x) {
		  S.insert(cur + (1LL<<i));
		}
    }
  }
  
	return (ll)S.size();
}
#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...