Submission #137368

#TimeUsernameProblemLanguageResultExecution timeMemory
137368HassoonyDetecting Molecules (IOI16_molecules)C++17
46 / 100
1072 ms912 KiB
#include <bits/stdc++.h> #include "molecules.h" //#include "grader.cpp" using namespace std; typedef long long ll; const int MX=5e5+9; bool dp[MX]; int last[MX]; vector<int> find_subset(int l, int u, vector<int> w) { dp[0]=1; last[0]=-1; for(int i=0;i<w.size();i++){ for(int j=u;j>=0;j--){ if(j-w[i] >= 0){ if(dp[j-w[i]] && !dp[j])dp[j]=1,last[j]=i; } } } vector<int>ret; int id=-1; for(int i=l;i<=u;i++){ if(dp[i]){id=i;break;} } if(id==-1)return ret; while(last[id]!=-1){ ret.push_back(last[id]); id-=w[ret.back()]; } return ret; }

Compilation message (stderr)

molecules.cpp: In function 'std::vector<int> find_subset(int, int, std::vector<int>)':
molecules.cpp:13:18: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     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...