题目描述

在一个m*n的棋盘每个格有一个礼物,每个礼物有一定价值(>0)。从棋盘左上角到右下角,只能向下或向右走,问能拿到的礼物最大价值。

解题思路

dp。

可将二维数组版优化为一维数组版。

代码

一维数组版

#include <iostream>
using namespace std; int maxSum(int* val,int rows,int cols){
if(!val||rows<=0||cols<=0){
return -1;
} int dp[cols];
memset(dp, 0, sizeof(dp)); for(int i=0;i<rows;i++){
for(int j=0;j<cols;j++){
if(i==0&&j==0){
dp[j]=val[i*cols+j];
}
else if(i==0){
dp[j]=dp[j-1]+val[i*cols+j];
}
else if(j==0){
dp[j]=dp[j]+val[i*cols+j];
}
else{
dp[j]=max(dp[j],dp[j-1])+val[i*cols+j];
}
}
}
return dp[cols-1];
} int main(int argc, const char * argv[]) {
int val[]={1,2,3,4,5,6};
int rows=2;
int cols=3;
int* pVal=val;
int sum=maxSum(pVal, rows, cols);
cout<<sum<<endl;
return 0;
}

二维数组版

#include <iostream>
using namespace std; int maxSum(int* val,int rows,int cols){
if(!val||rows<=0||cols<=0){
return -1;
} int dp[rows][cols];
memset(dp, 0, sizeof(dp)); for(int i=0;i<rows;i++){
for(int j=0;j<cols;j++){
if(i==0&&j==0){
dp[i][j]=val[i*cols+j];
}
else if(i==0){
dp[i][j]=dp[i][j-1]+val[i*cols+j];
}
else if(j==0){
dp[i][j]=dp[i-1][j]+val[i*cols+j];
}
else{
dp[i][j]=max(dp[i-1][j],dp[i][j-1])+val[i*cols+j];
}
}
}
return dp[rows-1][cols-1];
} int main(int argc, const char * argv[]) {
int val[]={1,2,3,4,5,6};
int rows=2;
int cols=3;
int* pVal=val;
int sum=maxSum(pVal, rows, cols);
cout<<sum<<endl;
return 0;
}

[剑指Offer]47-礼物的最大价值(DP)的更多相关文章

  1. 力扣 - 剑指 Offer 47. 礼物的最大价值

    题目 剑指 Offer 47. 礼物的最大价值 思路1 因为是要求最大价值,而且只能移动下方或者右方,因此,每个位置的最大值就是本身的值加上上边 / 左边 中的最大值,然后每次遍历都可以复用上一次的值 ...

  2. 【Java】 剑指offer(47) 礼物的最大价值

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 在一个m×n的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值( ...

  3. 每日一题 - 剑指 Offer 47. 礼物的最大价值

    题目信息 时间: 2019-07-02 题目链接:Leetcode tag:动态规划 难易程度:中等 题目描述: 在一个 m*n 的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于 0). ...

  4. 剑指 Offer 47. 礼物的最大价值

    题目描述 在一个 m*n 的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于 0).你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格.直到到达棋盘的右下角.给定一个棋盘及 ...

  5. 剑指offer——49礼物的最大价值

    题目描述 在一个m*n的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于0).你可以从棋盘的左上角开始拿格子里的礼物,并每次向左或者向下移动一格,知道到达棋盘的右下角.给定一个棋盘及其上面 ...

  6. 剑指Offer 47. 求1+2+3+...+n (其他)

    题目描述 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字及条件判断语句(A?B:C). 题目地址 https://www.nowcod ...

  7. [剑指Offer] 47.求1+2+3+...+n

    题目描述 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字及条件判断语句(A?B:C). [思路]用&&的短路思想来求和 ...

  8. 剑指offer——47把数组排成最小的数

    题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323.   题解: ...

  9. 剑指offer二刷(精刷)

    剑指 Offer 03. 数组中重复的数字 题目描述 在一个长度为 n 的数组里的所有数字都在 0 到 n-1 的范围内.数组中某些数字是重复的,但不知道有几个数字是重复的,也不知道每个数字重复几次. ...

随机推荐

  1. Apache通过配置.htaccess文件禁止访问.git、.svn等目录

    如果你用过Git.SVN等代码版本控制工具的话,那肯定会知道,如果你需要拉去最新的代码到本地时,会自动生成一个.git或者.svn文件夹,里面包含一些项目相关的信息,如果在部署项目是,把这些文件公开暴 ...

  2. Vim 常用命令和编辑方法

    命令模式 :e <path/to/file> → 打开一个文件 :w → 存盘 :wq → 存盘 + 退出 (:w 存盘, :q 退出)   (陈皓注::w 后可以跟文件名) :savea ...

  3. linux 不同服务器之间复制文件

    ----------------------拷贝文件夹---------------------------------------------- 把当前文件夹tempA拷贝到 目标服务器10.127 ...

  4. IP地址的含义

    不管是学习网络还是上网,IP地址都是出现频率非常高的词.Windows系统中设置IP地址的界面如图1所示,图中出现了IP地址.子网掩码.默认网关和DNS服务器这几个需要设置的地方,只有正确设置,网络才 ...

  5. 树莓派上的软件安装和卸载命令汇总 [ZT]

    转自:http://www.eeboard.com/bbs/thread-40823-1-1.html基础命令 安装软件 apt-get install softname1 softname2 sof ...

  6. 2008-03-18 22:58 oracle基础知识小结

    oracle 数据类型: 字段类型                 中文说明                                                  限制条件         ...

  7. subline 相关

    ctrl + ` 输入命令: import urllib.request,os; pf = 'Package Control.sublime-package'; ipp = sublime.insta ...

  8. JS计算滚动条的宽度

    1.此方法检验成功 function getScrollbarWidth() { var oP = document.createElement('p'), styles = { width: '10 ...

  9. eclipse git 分享项目到GitHub上

    先在github上创建仓库

  10. hdu1799-循环多少次?-(组合恒等式)

    循环多少次? Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...