走棋盘相关的一系列问题

问题一:

给定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的矩阵,每个位置是一个非负的权值,从左上角开始,每次只能朝右和下走,走到右下角;然后,从右下角开始,每次只能朝左和朝上走,走到左上角。求权值总和最小的路径。若相同格子走过两次,则该位置的权值只算一次。
待续





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值