Submission #134064

#TimeUsernameProblemLanguageResultExecution timeMemory
134064junodeveloperDetecting Molecules (IOI16_molecules)C++14
100 / 100
184 ms18180 KiB
#include "molecules.h" #include<bits/stdc++.h> using namespace std; std::vector<int> find_subset(int l, int u, std::vector<int> w) { vector<pair<int,int> > a; int i; for(i=0;i<w.size();i++) a.push_back({w[i],i}); sort(a.begin(),a.end()); set<pair<long long,int> > st; long long sum=0; st.insert({0,-1}); for(i=0;i<a.size();i++) { sum+=a[i].first; auto it=st.lower_bound({sum-u,-1}); if(it!=st.end()) { if(it->first<=sum-l) { vector<int> ans; for(int j=it->second+1;j<=i;j++) ans.push_back(a[j].second); return ans; } } st.insert({sum,i}); } return vector<int>(0); }

Compilation message (stderr)

molecules.cpp: In function 'std::vector<int> find_subset(int, int, std::vector<int>)':
molecules.cpp:7:11: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(i=0;i<w.size();i++) a.push_back({w[i],i});
          ~^~~~~~~~~
molecules.cpp:12:11: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(i=0;i<a.size();i++) {
          ~^~~~~~~~~
#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...