結果
問題 | No.2730 Two Types Luggage |
ユーザー |
|
提出日時 | 2024-04-19 21:30:46 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 299 ms / 2,000 ms |
コード長 | 1,083 bytes |
コンパイル時間 | 2,327 ms |
コンパイル使用メモリ | 201,080 KB |
最終ジャッジ日時 | 2025-02-21 03:45:49 |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 35 |
ソースコード
#include <bits/stdc++.h>using namespace std;long long int psum[1000001];int main(void){cin.tie(0);ios::sync_with_stdio(false);long long int n,m,w,t;vector <long long int> a,b,c;cin >> n >> m >> w;for(int i=0;i<n;i++){cin >> t;a.push_back(t);}for(int i=0;i<m;i++){cin >> t;b.push_back(t);}for(int i=0;i<m;i++){cin >> t;c.push_back(t);}sort(a.rbegin(),a.rend());for(int i=1;i<=n;i++){psum[i] = psum[i-1] + a[i-1];}long long int res = 0;for(int i=0;i<(1<<m);i++){long long int sum = 0;long long int val = 0;for(int j=0;j<m;j++){if((i&(1<<j))){sum += b[j];val += c[j];}}if(sum <= w){long long int idx = w - sum;idx = min(idx,(long long int)n);res = max(res,val + psum[idx]);}}cout << res << '\n';return 0;}