i'm working on algorithm problem have find minimum path sum of grid can move up, down, left, or right, , cannot repeat square. wrote recursive solution solve (i know dp better), outputs 0 answer every time, finds minimum sum 215 (should 87). how fix code solve it?
also, how use dp implement this?
here code:
#include<fstream> #include<iostream> #include<algorithm> int rows; int cols; /* * assumes max grid size 1000x1000 * go larger if necessary, memory use increase */ int grid[1000][1000]; bool ismarked[1000][1000]; int calc(int row, int col, int sum) { if (ismarked[row][col]) return int_max - sum; ismarked[row][col] = true; sum += grid[row][col]; if (row == rows-1 && col == cols-1) return sum; int ans[4]; if (row-1 >= 0) ans[0] = calc(row-1, col, sum); if (row+1 < rows) ans[1] = calc(row+1, col, sum); if (col+1 < cols) ans[2] = calc(row, col+1, sum); if (col-1 >= 0) ans[3] = calc(row, col-1, sum); ismarked[row][col] = false; return std::min(std::min(ans[0], ans[1]), std::min(ans[2], ans[3])); } int main() { std::ifstream fin("sum.in"); fin >> rows >> cols; (int = 0; < rows; i++) (int j = 0; j < cols; j++) fin >> grid[i][j]; int ans = calc(0, 0, 0); std::ofstream fout("sum.out"); fout << ans << std::endl; }
probably this:
int calc(int row, int col, int sum) { if (ismarked[row][col]) return int32_max; if (row == rows-1 && col == cols-1) return sum+grid[row][col]; ismarked[row][col] = true; int ans[4] = {int32_max, int32_max, int32_max, int32_max}; if (row-1 >= 0) ans[0] = calc(row-1, col, sum+grid[row][col]); if (row+1 < rows) ans[1] = calc(row+1, col, sum+grid[row][col]); if (col+1 < cols) ans[2] = calc(row, col+1, sum+grid[row][col]); if (col-1 >= 0) ans[3] = calc(row, col-1, sum+grid[row][col]); ismarked[row][col] = false; return std::min(std::min(ans[0], ans[1]), std::min(ans[2], ans[3])); }
Comments
Post a Comment