Submission #530704

#TimeUsernameProblemLanguageResultExecution timeMemory
530704CyanmondDetecting Molecules (IOI16_molecules)C++17
46 / 100
1097 ms2348 KiB
#include <bits/stdc++.h> template <typename T> using Vec = std::vector<T>; std::vector<int> find_subset(int L, int R, std::vector<int> W) { const int N = (int)W.size(); Vec<int> dp(R + 1, N); dp[0] = -1; for (int i = 0; i < N; ++i) { for (int j = R - W[i]; j >= 0; --j) { if (dp[j] == N) continue; const int next_w = j + W[i]; if (dp[next_w] == N) dp[next_w] = i; } } for (int answer_w = L; answer_w <= R; ++answer_w) { if (dp[answer_w] == N) continue; Vec<int> answer; int now = answer_w; while (now != 0) { const int new_id = dp[now]; answer.push_back(new_id); now -= W[new_id]; } return answer; } 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...