Submission #807181

#TimeUsernameProblemLanguageResultExecution timeMemory
807181ArturgoCookies (JOI23_cookies)C++14
100 / 100
233 ms259928 KiB
#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]; bits mask = ones; mask >>= cumul[k] + 1; mask <<= cumul[k] + 1; curLigne = curLigne & ~mask; if(curLigne[nbCookies] && k < minBoites) { minBoites = k; boiteOpt = iBoite; } 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 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...
#Verdict Execution timeMemoryGrader output
Fetching results...