Submission #1323211

#TimeUsernameProblemLanguageResultExecution timeMemory
1323211phoenix0423Detecting Molecules (IOI16_molecules)C++20
100 / 100
32 ms2752 KiB
#include "molecules.h"

#include<bits/stdc++.h>
using namespace std;

typedef long long ll;
#define pb push_back

std::vector<int> find_subset(int l, int u, std::vector<int> w) {
    int n = w.size();
    if(accumulate(w.begin(), w.end(), 0LL) < l) return {};
    vector<int> ans;
    vector<int> id(n);
    iota(id.begin(), id.end(), 0);
    sort(id.begin(), id.end(), [&](int a, int b){ return w[a] < w[b]; });
    ll cur = 0;
    for(int i = n - 1; i >= 0 && cur < l; i--){
        ans.pb(id[i]);
        cur += w[id[i]];
    }
    int p = 0, lim = ans.back();
    for(int i = 0; i < ans.size(); i++){
        if(cur <= u) break;
        if(id[p] == lim) break;
        cur += w[id[p]] - w[ans[i]];
        ans[i] = id[p++];
    }
    if(cur > u) return {};
    sort(ans.begin(), ans.end());
    return ans;
}

Compilation message (stderr)

molecules.h:1:9: warning: #pragma once in main file
    1 | #pragma once
      |         ^~~~
molecules_c.h:1:9: warning: #pragma once in main file
    1 | #pragma once
      |         ^~~~
#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...