问题一:
给定m*n的矩阵,从左上角开始,每次只能朝右和下走,走到右下角,问有多少种走法?
思路:其实就是在m+n步中选择m步向下的和n步向右的,所以就是C(m+n,m) 或C(m+n,n),这两者一样
问题二:
给定m*n的矩阵,每个位置是一个非负整数,从左上角开始,每次只能朝右和下走,走到右下角,求最小的路径和。
思路:动态规划,每个节点只能来自上边和左边,所以很容易想出状态转移方程
dp[x][y]=min(dp[x-1][y], dp[x][y-1])+matrix[x][y]
代码如下:
int minPathSum(vector<vector<int> > &grid) {
int m=grid.size();
int n=grid[0].size();
int b[m][n];
b[0][0]=grid[0][0];
for(int i=1;i<m;i++){
b[i][0]=b[i-1][0]+grid[i][0];
}
for(int i=1;i<n;i++){
b[0][i]=b[0][i-1]+grid[0][i];
}
for(int i=1;i<m;i++){
for(int j=1;j<n;j++){
b[i][j]=min(b[i-1][j],b[i][j-1])+grid[i][j];
}
}
return b[m-1][n-1];
}
给定m*n的矩阵,每个位置是一个非负整数,从左上角开始,每次只能朝右和下走,走到右下角,求最小的路径。
路径怎么求??
思路:每一步都记录自己是由谁过来的,到最后一个节点倒推回去。
问题四:
o给定m*n的矩阵,每个位置是一个非负的权值,从左上角开始,每次只能朝右和下走,走到右下角;然后,从右下角开始,每次只能朝左和朝上走,走到左上角。求权值总和最小的路径。若相同格子走过两次,则该位置的权值只算一次。
待续