제출 #1015007

#제출 시각아이디문제언어결과실행 시간메모리
1015007ziyad_alharbiDetecting Molecules (IOI16_molecules)C++17
31 / 100
375 ms65536 KiB
#include <bits/stdc++.h> using namespace std; int n; int L, R; pair<int, int>wh[200005]; bool b; set<pair<int, int>>g; set<int>st; void f(int x,int s) { //cout << x << ' '; if (s >= L&&!b) { b = 1; return; } if (x == n || b || wh[x].first + s > R || g.count({ x,s }))return; //cout << x << ' ' << s << '\n'; st.insert(wh[x].second); f(x + 1, s + wh[x].first); if (b)return; st.erase(wh[x].second); f(x + 1, s); g.insert({ x,s }); } vector<int> find_subset(int l, int u, vector<int> w) { n = w.size(); long long s = 0; for (int x = 0; x < n; x++) { wh[x].first = w[x]; wh[x].second = x; s += w[x]; } sort(wh, wh + n); L = l; R = u; if (s >= L && s <= R) { vector<int>a; for (int x = 0; x < n; x++) { a.push_back(x); } return a; } else if (s < L) { return vector<int>(0); } f(0, 0); if (st.size()) { vector<int>a; for (auto i : st) { a.push_back(i); } return a; } else { return vector<int>(0); } } /*signed main() { //ios::sync_with_stdio(0); //cin.tie(0); int t = 1; //cin>>t; while (t--) { int N, L, R; cin >> N >> L >> R; vector<int> w(N); for (int x = 0; x < N; x++) { cin >> w[x]; } vector<int>a = find_subset(L, R, w); int nh = a.size(); for (int x = 0; x < nh; x++)cout << a[x] << ' '; } return 0; }*/
#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...