Advertisement
Hamoudi30

max path

Jan 5th, 2022
106
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 0.81 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. // 8-D check
  4. const int N = 100;
  5. int n, m;
  6. int grid[N][N];
  7. bool valid (int row, int col) {
  8. return (row >= 0 && col >= 0 && row < n && col < m);
  9. }
  10. int max_path (int row, int col) {
  11. // base case
  12.  
  13. if (!valid(row, col))
  14. return false;
  15. if (row == n - 1 && col == m - 1)
  16. return grid[row][col];
  17.  
  18. // recursive case
  19.  
  20. int down = grid[row][col] + max_path(row + 1, col);
  21. int right = grid[row][col] + max_path(row, col + 1);
  22. return max(down, right);
  23. }
  24.  
  25. int main() {
  26.  
  27. freopen("/home/hamoudi/Coding/run.in", "r", stdin);
  28.  
  29. cin >> n >> m;
  30. for (int i = 0; i < n; ++i)
  31. for (int j = 0; j < m; ++j)
  32. cin >> grid[i][j];
  33.  
  34. cout << max_path(0, 0) << '\n';
  35.  
  36. return 0;
  37. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement