Submission #571068

#TimeUsernameProblemLanguageResultExecution timeMemory
571068webDetecting Molecules (IOI16_molecules)C++17
0 / 100
1 ms296 KiB
#include <iostream> #include "molecules.h" #include <algorithm> using namespace std; vector<vector<int>> dp; void knapsack(vector<int>& weights, int u) { for(int i = 0; i<weights.size(); ++i) { for(int weight = 0; weight <= u; ++weight) { if(weight < weights[i]) { dp[i+1][weight] = dp[i][weight]; } else { if(dp[i][weight] >= dp[i][weight - weights[i]]+ weights[i]) { dp[i+1][weight] = dp[i][weight]; } else { dp[i+1][weight] = dp[i][weight-weights[i]] + weights[i]; } } } } } std::vector<int> find_subset(int l, int u, std::vector<int> w) { vector<pair<int,int>> wP(w.size()); for(int i = 0; i<w.size(); ++i) { wP[i] = {w[i], i}; } sort(wP.begin(), wP.end()); //construct prefix auto itStart = wP.begin(); auto itPrefEnd = wP.begin(); auto itSuffixStart = wP.end(); int sum = 0; while(sum <= u && itPrefEnd != wP.end()) { sum += (*itPrefEnd).first; itPrefEnd++; } if(sum > u) { itPrefEnd--; sum-= (*itPrefEnd).first; } //for(auto n:w) // cout<<n<<" "; //cout<<endl; //cout<<"sum: "<<sum<<endl; // cout<<"pos itstart: "<<itStart-wP.begin()<<endl; //cout<<"pos itPrefEnd: "<<itPrefEnd-wP.begin()<<endl; while(sum < l && itPrefEnd != itSuffixStart) { sum -= (*itStart).first; itStart++; itSuffixStart--; sum += (*itSuffixStart).first; // cout<<"new sum " << sum<<endl; } if(sum >= l && sum <= u) { vector<int> retVal; while(itStart != itPrefEnd) {retVal.push_back((*itStart).second+1); itStart++;} while(itSuffixStart != wP.end()) { retVal.push_back((*itSuffixStart).second +1); itSuffixStart++; } return retVal; } else return vector<int>(0); }

Compilation message (stderr)

molecules.cpp: In function 'void knapsack(std::vector<int>&, int)':
molecules.cpp:9:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    9 |     for(int i = 0; i<weights.size(); ++i)
      |                    ~^~~~~~~~~~~~~~~
molecules.cpp: In function 'std::vector<int> find_subset(int, int, std::vector<int>)':
molecules.cpp:37:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   37 |     for(int i = 0; i<w.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...