49362023-04-07 16:48:05TomaSajtDinamitcpp17Hibás válasz 18/506ms4348 KiB
#include <bits/stdc++.h>
using namespace std;

int main() {
  cin.tie(0), ios::sync_with_stdio(0);
  int n, m, k;
  cin >> n >> m >> k;
  vector<vector<int>> board(n + 1, vector<int>(m + 1));
  for (int i = 1; i <= n; i++) {
    for (int j = 1; j <= m; j++) {
      cin >> board[i][j];
    }
  }

  // what is the min cost of getting to [i;j] with d dynamites
  vector<vector<vector<int>>> dp(n + 1, vector<vector<int>>(m + 1, vector<int>(k + 1, INT_MAX / 2)));

  dp[1][1][0] = board[1][1];
  for (int i = 1; i <= n; i++) {
    for (int j = 1; j <= m; j++) {
      for (int d = 0; d <= k; d++) {
        if (i == 1 && j == 1 && d == 0)
          continue;
        for (int dd = 0; dd <= d; dd++) {
          dp[i][j][d] = min(dp[i][j][d], (board[i][j] >> dd) + min(dp[i][j - 1][d - dd], dp[i - 1][j][d - dd]));
        }
      }
    }
  }
  cout << dp[n][m][k];
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base18/50
1Elfogadva0/03ms1828 KiB
2Hibás válasz0/06ms2740 KiB
3Elfogadva2/23ms2560 KiB
4Elfogadva2/23ms2732 KiB
5Elfogadva3/33ms2892 KiB
6Elfogadva3/33ms3008 KiB
7Elfogadva2/26ms3424 KiB
8Hibás válasz0/36ms3564 KiB
9Hibás válasz0/23ms3240 KiB
10Hibás válasz0/23ms3188 KiB
11Hibás válasz0/33ms3192 KiB
12Hibás válasz0/33ms3448 KiB
13Elfogadva2/23ms3468 KiB
14Hibás válasz0/33ms3476 KiB
15Elfogadva2/26ms4336 KiB
16Hibás válasz0/36ms4296 KiB
17Hibás válasz0/26ms4300 KiB
18Hibás válasz0/36ms4092 KiB
19Elfogadva2/26ms4096 KiB
20Hibás válasz0/36ms4348 KiB
21Hibás válasz0/26ms4292 KiB
22Hibás válasz0/36ms4292 KiB