剑指Offer 礼物的最大值

与机器人的运动范围的区别
矩阵的路径,机器人的运动范围和礼物最大值都是矩阵,但礼物的最大值有一点不同便是:存在子问题重叠,这就可以用动态规划来解决了。
矩阵中的路径问题分解成上,下,左,右四个子问题,礼物的最大值问题分解成上或左两个子问题,而在上和左的问题是存在重叠的,可以用动态规划。上下左右的子问题不存在重叠,因为每次都和上一次的路径有关。
礼物的最大值

获取二维数据的行和列

int rows = grid.length, cols = grid[0].length;

动态规划核心:新建result数组。然后是自底向上遍历,所以两个for循环。矩阵动态规划result二维的。

for(int row=0; row<rows; row++){
    for(int col=0; col<cols; col++){
        if(row==0 || col==0)
            result[row][col] = 0;
        else
            result[row][col] = grid[row][col]+Math.max(
            				 result[row-1][col], result[row][col-1]);
    }
}
return result[rows-1][cols-1];

矩阵就会涉及row,col小于零的问题。剑指的思路是新建了两个变量。(又慢思路又不顺)
改写成 row||col等于0 和 row&&col都大于0两种情况,既if……else……

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值