Submission #745819

#TimeUsernameProblemLanguageResultExecution timeMemory
745819vjudge1Kitchen (BOI19_kitchen)C++17
9 / 100
2 ms212 KiB
#include <bits/stdc++.h> using namespace std; #define InTheNameOfGod ios::sync_with_stdio(0);cin.tie(0); cout.tie(0); using ll = long long; const int maxN = 2e5 + 5; const int MOD = 1e9 + 7; const int INF = 1e9 + 7; int main() { /*#ifndef ONLINE_JUDGE freopen("../../input.txt", "r", stdin); freopen("../../output.txt", "w", stdout); #endif*/ InTheNameOfGod; int n,m,k; cin >>n >> m >> k; vector<int> a(n),b(m); int s = 0, must = (n)*(k-1); bool ok = 0; for(int i = 0; i < n; i++) { cin >> a[i]; s += a[i]; if(a[i] < k) ok = 1; } for(int &i : b) cin >> i; if(ok || m < k) { cout << "Impossible\n"; return 0; } int mo = INF; for(int mask = 1; mask < (1<<m); mask++) { int sum = 0, maxi = -1; if(__builtin_popcount(mask) < k) continue; for(int i = 0; i < m; i++) { if((1<<i) & mask) { sum += b[i]; maxi = max(maxi, b[i]); } } /*cout << "mask: " <<mask << endl; cout << "sum: " << sum << endl; cout << "s: " << s << endl;*/ if(sum >= s && must <= sum - maxi) { mo = min(mo, sum - s); } } if(mo == INF) cout << "Impossible\n"; else cout << mo; 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...