Submission #798294

#TimeUsernameProblemLanguageResultExecution timeMemory
798294LiudasDetecting Molecules (IOI16_molecules)C++17
31 / 100
1086 ms1008 KiB
#include <bits/stdc++.h>

using namespace std;
vector<int> find_subset(int L, int R, vector<int> M){
    int N = M.size();
    set<int> pos;
    for(int i = 0; i < N; i ++){
        pos.insert(i);
    }
    bitset<500000> bits;
    bits[0] = 1;
    for(int i = 0; i < N; i ++){
        int a = M[i];
        bits |= (bits << a);
    }
    int t = 0;
    for(int i = L; i <= R; i ++){
        if(bits[i]){t = i;break;}
    }
    vector<int> p;
    while(t){
        for(int i : pos){
            if(t >= M[i] && bits[t - M[i]]){
                t -= M[i];
                pos.erase(i);
                p.push_back(i);
                break;
            }
        }
    }
    return p;
}
#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...