Advertisement
informaticage

Corsa Contro il Tempo rec

Mar 7th, 2023
767
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.94 KB | None | 0 0
  1. #include <algorithm>
  2. #include <iostream>
  3. #include <vector>
  4.  
  5. using namespace std;
  6.  
  7. int solve(vector<int> &time, vector<int> &charge, int charge_limit, int current_charge, int i) {
  8.   if (i == time.size()) return 0;
  9.  
  10.   // Se posso eventualmente skippare utilizzando la carica
  11.   if (current_charge >= charge_limit) {
  12.     int skip = time.at(i) + solve(time, charge, charge_limit, current_charge + charge.at(i), i + 1);
  13.     int no_skip = solve(time, charge, charge_limit, 0, i + 1);
  14.  
  15.     return min(skip, no_skip);
  16.   }
  17.  
  18.   return time.at(i) + solve(time, charge, charge_limit, current_charge + charge.at(i), i + 1);
  19. }
  20.  
  21. int main() {
  22.   freopen("input.txt", "r", stdin);
  23.   freopen("output.txt", "w", stdout);
  24.  
  25.   int N, C;
  26.   cin >> N >> C;
  27.  
  28.   vector<int> time(N);
  29.   vector<int> charge(N);
  30.  
  31.   for (int &t : time) {
  32.     cin >> t;
  33.   }
  34.  
  35.   for (int &c : charge) {
  36.     cin >> c;
  37.   }
  38.  
  39.   cout << solve(time, charge, C, 0, 0);
  40.   return 0;
  41. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement