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 <iostream>
#include <vector>
#include <algorithm>
#include <cmath>
#include <set>
using namespace std;
#define ll long long
struct comp{
int poz, val;
};
bool rule(comp A, comp B)
{
if (A.val == B.val)
return A.poz < B.poz;
return A.val < B.val;
}
vector<int> find_subset(int l, int u, vector<int> v)
{
int n = v.size();
set<int> Set;
vector<int> result;
vector<comp> w(n);
for (int i = 0; i < n; i++)
{
w[i].val = v[i];
w[i].poz = i;
}
sort(w.begin(), w.end(), rule);
if(u < w[0].val)
return result;
if (u - l < w[n-1].val - w[0].val)
return result;
ll sum = 0;
int i;
for (i = 0; i < n; i++)
{
if (sum + w[i].val > u)
break;
sum+= w[i].val;
Set.insert(w[i].val);
}
int dif = u - sum;
while (i < n && !(l <= sum && sum <= u))
{
auto poz = Set.lower_bound(w[i].val - dif);
if (poz == Set.end())
break;
sum= sum - *poz + w[i].val;
Set.erase(poz);
Set.insert(w[i].val);
i++;
}
if (l <= sum && sum <= u)
{
auto p = Set.begin();
for(i = 0; i < n; i++)
if (w[i].val == *p)
{
result.push_back(w[i].poz);
Set.erase(p);
p = Set.begin();
}
}
return result;
}
/*
int main()
{
int n, u, l;
cin>> n >> l >> u;
vector<int> v(n);
for (int i = 0; i < n; i++)
cin>> v[i];
vector<int> ans = find_subset(l, u, v);
for (int i = 0; i < ans.size(); i++)
cout<< ans[i] + 1 << " ";
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... |