Submission #1362774

#TimeUsernameProblemLanguageResultExecution timeMemory
1362774cowkimPacking Biscuits (IOI20_biscuits)C++20
0 / 100
1128 ms1155780 KiB
#include "biscuits.h"
#include <bits/stdc++.h>
using namespace std;
#define int long long
#define DEBUG 0
int binarysearch(int x, vector<int>& arr){
	int l = -1;
	int r = arr.size();
	// cout << "startb" << endl;
	while(l+1 < r){
		int mid = (l+r)/2;
		if(arr[mid] <= x) l = mid;
		else r = mid;
	}
	// cout << "endb" << endl;
	// cout << l << endl;
	return l;
}
long long count_tastiness(long long x, std::vector<long long> a) {
	vector<int> answers = {0};
	int tot = 0;
	for(int bi = 0; bi <= 61; bi++){
		if(bi < a.size()) tot += a[bi] << bi;
		int needed = x*(1ll<<bi);
		int biggie = binarysearch(tot - needed,answers);
		for(int i = 0; i <= biggie; i++){
			answers.push_back(answers[i] + needed);
		}
	}
	return answers.size()-1;
}
#if DEBUG
signed main(){
	int n,x;
	cin >> n >> x;
	vector<int> a(n);
	for(auto& x : a) cin >> x;
	int ans = count_tastiness(x,a);
	cout << ans << endl;
}
#endif

#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...
#Result Execution timeMemoryGrader output
Fetching results...