Submission #1292842

#TimeUsernameProblemLanguageResultExecution timeMemory
1292842enzyPacking Biscuits (IOI20_biscuits)C++20
In queue
0 ms0 KiB
#include "biscuits.h"
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxk=62;
vector<pair<ll,ll>>dp[maxk];
ll count_tastiness(ll x, vector<ll> v){
	reverse(v.begin(),v.end());
	v.push_back(0);
	reverse(v.begin(),v.end());
	while(v.size()<=61) v.push_back(0);
	ll resp=1;
	dp[0].push_back({1,0});
	for(int i=1;i<=60;i++){
		// calcular a resp agr pro bit i-1
		cout << "? " << v[i] << endl;
		for(int j=i-1;j>=0;j--){
			for(pair<ll,ll>p : dp[j]){
				ll sum=p.second; // qnt terei de i para pagar
				for(int l=j;l<=i;l++){
					sum+=v[l];
					sum/=2;
				}
				if(sum>=x){
					dp[i].push_back({p.first,(sum-x)/2});
					resp+
				}
			}
		}
		cout << "! " << i << " " << resp << endl;
		for(pair<ll,ll> p : dp[i]) cout << p.first << " " << p.second << endl;
		cout << endl;
	}
	return resp;
}