Submission #309459

#TimeUsernameProblemLanguageResultExecution timeMemory
309459cig32Detecting Molecules (IOI16_molecules)C++14
100 / 100
61 ms7544 KiB
#include "molecules.h" #include<bits/stdc++.h> #define ll long long using namespace std; std::vector<int> find_subset(int l,int u,std::vector<int>x){ ll n=x.size(); pair<ll,ll> w[n]; bool used[n]; ll tot_sum=0; for(int i=0;i<n;i++)w[i].first=x[i]; for(int i=0;i<n;i++)w[i].second=i; for(int i=0;i<n;i++)tot_sum+=w[i].first; for(int i=0;i<n;i++)used[i]=false; sort(w,w+n); ll curr_sum=0, pt=0, nani=0; for(int i=0;i<n;i++){ curr_sum+=w[i].first; if(u<curr_sum){ curr_sum-=w[i].first; pt=i; break; } used[i]=true; nani++; if(l<=curr_sum&&curr_sum<=u){ vector<int>v; for(int j=0;j<n;j++){ if(used[j])v.push_back(w[j].second); } return v; } } for(int i=0;i<min(n-pt,pt);i++){ curr_sum-=w[i].first; used[i]=false; curr_sum+=w[n-i-1].first; used[n-i-1]=true; if(l<=curr_sum&&curr_sum<=u){ break; } } if(l<=curr_sum&&curr_sum<=u){ vector<int>v; for(int i=0;i<n;i++){ if(used[i])v.push_back(w[i].second); } return v; } else{ vector<int>v; return v; } }
#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...