Submission #900405

#TimeUsernameProblemLanguageResultExecution timeMemory
900405n3rm1nKitchen (BOI19_kitchen)C++17
29 / 100
1061 ms1116 KiB
#include<bits/stdc++.h> #define endl '\n' using namespace std; const long long MAXN = 305; void speed() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); } long long n, m, k; long long a[MAXN], b[MAXN]; long long total = 0; void read() { cin >> n >> m >> k; for (long long i = 1; i <= n; ++ i) { cin >> a[i]; total += a[i]; } for (long long i = 1; i <= m; ++ i) cin >> b[i]; for (long long i = 1; i <= n; ++ i) { if(a[i] < k) { cout << "Impossible" << endl; exit(0); } } } long long taken[MAXN]; long long p[MAXN], notused[MAXN]; long long solve() { memset(taken, 0, sizeof(taken)); memset(notused, 0, sizeof(notused)); long long left = total, sumup = 0; long long ok = 0; for (long long i = 1; i <= m; ++ i) { if(p[i]) { notused[i] = b[i]; for (long long j = 1; j <= n; ++ j) { if(taken[j] < k && notused[i] > 0) { taken[j] ++; if(taken[j] == k)ok ++; notused[i] --; left --; } } sumup += notused[i]; } } if(sumup < left || ok < n)return 1e13; else { return sumup - left; } } long long ans = 1e13; void gen(long long pos) { if(pos > m) { ans = min(ans, solve()); return; } p[pos] = 0; gen(pos+1); p[pos] = 1; gen(pos+1); } long long dp[MAXN * MAXN + MAXN * MAXN]; void solve_k1() { dp[0] = 1; for (long long i = 1; i <= m; ++ i) { for (long long j = total; j >= 0; -- j) if(dp[j])dp[j+b[i]] = 1; } for (long long i = total; i <= 2*total; ++ i) { if(dp[i]) { cout << i - total << endl; exit(0); } } cout << "Impossible" << endl; } int main() { speed(); read(); if(k == 1) { solve_k1(); return 0; } gen(1); if(ans == 1e13)cout << "Impossible" << endl; else cout << ans << endl; return 0; } /** 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 14 14 16 16 16 17 16 15 14 16 15 14 17 15 17 */
#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...