Submission #949433

#TimeUsernameProblemLanguageResultExecution timeMemory
949433Darren0724Kitchen (BOI19_kitchen)C++17
0 / 100
122 ms262144 KiB
#include <bits/stdc++.h> using namespace std; #define LCBorz ios_base::sync_with_stdio(false); cin.tie(0); #define int long long #define all(x) x.begin(), x.end() #define endl '\n' #define no cout<<"Impossible"<<endl;return 0; const int N=200005; const int INF=1e18; int32_t main() { LCBorz; int n,m,k;cin>>n>>m>>k; if(m<k){ no; } vector<int> a(n),b(m); int total=0,ta=0,tb=0; for(int i=0;i<n;i++){ cin>>a[i]; if(a[i]<k){ no; } total+=a[i]; } for(int i=0;i<m;i++){ cin>>b[i]; ta+=b[i]; tb+=min(n,b[i]); } vector dp(ta+1,vector(tb+1,0)); dp[0][0]=1; for(int i=0;i<m;i++){ for(int j=ta;j>=b[i];j--){ int tmp=min(b[i],n); for(int j1=tb;j1>=tmp;j1--){ dp[j][j1]|=dp[j-b[i]][j1-tmp]; } } } /*for(int i=0;i<=ta;i++){ for(int j=0;j<=tb;j++){ cout<<dp[i][j]<<' '; } cout<<endl; }*/ int ans=-1; for(int i=total;i<=ta;i++){ for(int j=k;ans==-1&&j<=tb;j++){ if(dp[i][j]){ ans=i;break; } } } if(ans==-1){ no; } else{ cout<<ans-total<<endl; } 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...