Submission #1021939

#TimeUsernameProblemLanguageResultExecution timeMemory
1021939amirhoseinfar1385Detecting Molecules (IOI16_molecules)C++17
100 / 100
39 ms9664 KiB
#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 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...