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 "molecules.h"
#include<bits/stdc++.h>
using namespace std;
const int maxn=200000+10;
int n;
long long suma=0,mina=(1<<31),ps[maxn],all[maxn];
std::vector<int> find_subset(int l, int u, std::vector<int> w) {
n=w.size();
vector<pair<long long ,long long>>lnk;
for(int i=0;i<n;i++){
lnk.push_back(make_pair(w[i],i));
}
sort(lnk.begin(),lnk.end());
for(int i=0;i<n;i++){
w[i]=lnk[i].first;
}
for(auto x:w){
suma+=x;
mina=min(mina,1ll*x);
}
if(l>suma||u<mina){
return {};
}
for(int i=1;i<=n;i++){
ps[i]=ps[i-1]+w[i-1];
}
for(int i=1;i<=n;i++){
if((ps[i]>=l&&ps[i]<=u)||((ps[n]-ps[n-i])>=l&&(ps[n]-ps[n-i])<=u)||(ps[i]<l&&ps[n]-ps[n-i]>u)){
for(int j=i;j<=n;j++){
if(ps[j]-ps[j-i]>=l&&ps[j]-ps[j-i]<=u){
vector<int>ret;
for(int k=j-i+1;k<=j;k++){
ret.push_back(lnk[k-1].second);
}
return ret;
}
}
}
}
return {};
}
# | 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... |