This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
const int MAX_COOKIES = 15000 + 1;
using bits = bitset<MAX_COOKIES>;
int nbTypes, nbBoites, nbCookies;
vector<int> tailles;
int profil[MAX_COOKIES], cumul[MAX_COOKIES];
priority_queue<pair<int, int>> nbs;
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL); cout.tie(NULL);
bits zeroes, ones;
ones = ~zeroes;
cin >> nbTypes;
for(int iType = 0;iType < nbTypes;iType++) {
int nb;
cin >> nb;
nbs.push({nb, iType + 1});
nbCookies += nb;
for(int iDiff = 0;iDiff < nb;iDiff++) {
profil[iDiff]++;
}
}
for(int iCookie = 0;iCookie < nbCookies;iCookie++) {
cumul[iCookie + 1] = cumul[iCookie] + profil[iCookie];
}
cin >> nbBoites;
for(int iBoite = 0;iBoite < nbBoites;iBoite++) {
int taille;
cin >> taille;
tailles.push_back(taille);
}
reverse(tailles.begin(), tailles.end());
// iBoite, k, somme
vector<vector<bits>> dyn;
int minBoites = nbCookies + 1;
int boiteOpt = 0;
for(int iBoite = 0;iBoite < nbBoites;iBoite++) {
vector<bits> curCouche;
bits premLigne;
premLigne[0] = 1;
curCouche.push_back(premLigne);
for(int k = 1;k * tailles[iBoite] <= nbCookies;k++) {
bits curLigne = curCouche.back() << tailles[iBoite];
if(!dyn.empty() && k < (int)dyn.back().size())
curLigne |= dyn.back()[k];
if(curLigne[nbCookies] && k < minBoites) {
minBoites = k;
boiteOpt = iBoite;
}
bits mask = ones;
mask >>= cumul[k] + 1;
mask <<= cumul[k] + 1;
curLigne = curLigne & ~mask;
curCouche.push_back(curLigne);
}
dyn.push_back(curCouche);
}
if(minBoites > nbCookies) {
cout << -1 << endl;
return 0;
}
cout << minBoites << endl;
// reconstruct the sizes
int curBoite = boiteOpt;
int curK = minBoites;
int curSomme = nbCookies;
vector<int> optTailles;
while(curK != 0) {
while(tailles[curBoite] <= curSomme && dyn[curBoite][curK - 1][curSomme - tailles[curBoite]]) {
optTailles.push_back(tailles[curBoite]);
curSomme -= tailles[curBoite];
curK--;
}
curBoite--;
}
for(int taille : optTailles) {
cout << taille << " ";
vector<pair<int, int>> to_insert;
for(int iElem = 0;iElem < taille;iElem++) {
pair<int, int> p = nbs.top();
nbs.pop();
cout << p.second << " ";
p.first--;
if(p.first) {
to_insert.push_back(p);
}
}
for(pair<int, int> p : to_insert) {
nbs.push(p);
}
cout << endl;
}
return 0;
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |