Submission #745871

#TimeUsernameProblemLanguageResultExecution timeMemory
745871vjudge1Kitchen (BOI19_kitchen)C++17
100 / 100
140 ms100708 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, s2 = 0,  must = (n)*(k-1);
    bool ok = 0;
    for(int i = 0; i < n; i++)  {
        cin >> a[i];
        s2 += a[i];
        if(a[i] < k) ok = 1;
    }

    for(int &i : b) {
        cin >> i;
        s += i;
    }

    if(ok || m < k) {
        cout << "Impossible\n";
        return 0;
    }

    vector<vector<int> > dp(m+1, vector<int> (s+1, INF));
    int mo = INF;
    dp[0][0] = n*k;
    for(int i = 0; i < m; i++)  {
        for(int j = 0; j <= s; j++) {
            if(dp[i][j] != INF) {
                dp[i+1][j] = min(dp[i+1][j], dp[i][j]);
                if(j + b[i] >= s2 && dp[i][j] - min(b[i], n) <= 0) mo = min(mo, j+b[i] - s2);
                dp[i+1][j+b[i]] = min(dp[i+1][j+b[i]], dp[i][j] - min(b[i], n));
            }

            //cout << i << ", " << j << ": " << dp[i][j] << endl;
        }
    }
    if(mo == INF) cout << "Impossible" << endl;
    else cout << mo << endl;

    return 0;
}

Compilation message (stderr)

kitchen.cpp: In function 'int main()':
kitchen.cpp:23:25: warning: unused variable 'must' [-Wunused-variable]
   23 |     int s = 0, s2 = 0,  must = (n)*(k-1);
      |                         ^~~~
#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...