Advertisement
Josif_tepe

Untitled

Mar 3rd, 2022
1,084
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.05 KB | None | 0 0
  1. #include <iostream>
  2. #include <vector>
  3. #include <queue>
  4. #include <algorithm>
  5. using namespace std;
  6. int n, W;
  7. int w[105], v[105];
  8. long long dp[105][100005];
  9.  
  10. long long rek(int idx, int value) {
  11.     if(value == 0) {
  12.         return 0;
  13.     }
  14.     if(idx == n) {
  15.         return 2e9;
  16.     }
  17.     if(dp[idx][value] != -1) {
  18.         return dp[idx][value];
  19.     }
  20.     long long result = 2e9;
  21.     result = min(result, rek(idx + 1, value));
  22.     if(value >= v[idx]) {
  23.         result = min(result, rek(idx + 1, value - v[idx]) + w[idx]);
  24.     }
  25.     dp[idx][value] = result;
  26.     return result;
  27. }
  28. int main()
  29. {
  30.     ios_base::sync_with_stdio(false);
  31.     cout.tie(0);
  32.     cin.tie(0);
  33.     cin >> n >> W;
  34.     for(int i = 0; i < n; i++) {
  35.         cin >> w[i] >> v[i];
  36.     }
  37.     for(int i = 0; i < n; i++) {
  38.         for(int j = 0; j <= 100000; j++) {
  39.             dp[i][j] = -1;
  40.         }
  41.     }
  42.    
  43.     for(int i = 100000; i >= 0; i--) {
  44.         if(rek(0, i) <= W) {
  45.             cout << i << endl;
  46.             break;
  47.         }
  48.     }
  49.     return 0;
  50.  
  51. }
  52.  
  53.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement