// 面试题47:礼物的最大价值
// 题目:在一个m×n的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值
// (价值大于0)。你可以从棋盘的左上角开始拿格子里的礼物,并每次向左或
// 者向下移动一格直到到达棋盘的右下角。给定一个棋盘及其上面的礼物,请计
// 算你最多能拿到多少价值的礼物? #include <algorithm>
#include <iostream> int getMaxValue_solution1(const int* values, int rows, int cols)
//使用一个二维辅助空间
{
if (values == nullptr || rows <= || cols <= )
return ; int** maxValues = new int*[rows];//定义一个二维数组,用来存储当前位置最大值
for (int i = ; i < rows; ++i)
maxValues[i] = new int[cols]; for (int i = ; i < rows; ++i)
{
for (int j = ; j < cols; ++j)
{
int left = ;
int up = ; if (i > )//如果有
up = maxValues[i - ][j]; if (j > )
left = maxValues[i][j - ]; maxValues[i][j] = std::max(left, up) + values[i * cols + j];
}
} int maxValue = maxValues[rows - ][cols - ];//取出右下角最大值 for (int i = ; i < rows; ++i)//删除它们
delete[] maxValues[i];
delete[] maxValues; return maxValue;
} int getMaxValue_solution2(const int* values, int rows, int cols)
//空间优化,将二维辅助数组变为一维
{
if (values == nullptr || rows <= || cols <= )
return ; int* maxValues = new int[cols];
for (int i = ; i < rows; ++i)
{
for (int j = ; j < cols; ++j)
{
int left = ;
int up = ; if (i > )
up = maxValues[j]; if (j > )
left = maxValues[j - ]; maxValues[j] = std::max(left, up) + values[i * cols + j];//更新maxValues[j]值就好了
}
} int maxValue = maxValues[cols - ]; delete[] maxValues; return maxValue;
} // ====================测试代码====================
void test(const char* testName, const int* values, int rows, int cols, int expected)
{
if (getMaxValue_solution1(values, rows, cols) == expected)
std::cout << testName << ": solution1 passed." << std::endl;
else
std::cout << testName << ": solution1 FAILED." << std::endl; if (getMaxValue_solution2(values, rows, cols) == expected)
std::cout << testName << ": solution2 passed." << std::endl;
else
std::cout << testName << ": solution2 FAILED." << std::endl;
} void test1()
{
// 三行三列
int values[][] = {//看看秀儿的二维数组定义方法
{ , , },
{ , , },
{ , , }
};
int expected = ;
test("test1", (const int*)values, , , expected);
} void test2()
{
//四行四列
int values[][] = {
{ , , , },
{ , , , },
{ , , , },
{ , , , }
};
int expected = ;
test("test2", (const int*)values, , , expected);
} void test3()
{
// 一行四列
int values[][] = {
{ , , , }
};
int expected = ;
test("test3", (const int*)values, , , expected);
} void test4()
{
int values[][] = {
{ },
{ },
{ },
{ }
};
int expected = ;
test("test4", (const int*)values, , , expected);
} void test5()
{
// 一行一列
int values[][] = {
{ }
};
int expected = ;
test("test5", (const int*)values, , , expected);
} void test6()
{
// 空指针
int expected = ;
test("test6", nullptr, , , expected);
} int main(int argc, char* argv[])
{
test1();
test2();
test3();
test4();
test5();
system("pause");
return ;
}

《剑指offer》第四十七题(礼物的最大价值)的更多相关文章

  1. 《剑指offer》第二十七题(二叉树的镜像)

    // 面试题27:二叉树的镜像 // 题目:请完成一个函数,输入一个二叉树,该函数输出它的镜像. #include <iostream> #include "BinaryTree ...

  2. 《剑指offer》第十七题(打印1到最大的n位数)

    // 面试题17:打印1到最大的n位数 // 题目:输入数字n,按顺序打印出从1最大的n位十进制数.比如输入3,则 // 打印出1.2.3一直到最大的3位数即999. #include <ios ...

  3. 《剑指offer》面试题47. 礼物的最大价值

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

  4. 剑指offer第四章

    剑指offer第四章 1.二叉树的镜像 二叉树的镜像:输入一个二叉树,输出它的镜像 分析:求树的镜像过程其实就是在遍历树的同时,交换非叶结点的左右子结点. 求镜像的过程:先前序遍历这棵树的每个结点,如 ...

  5. 剑指Offer(三十七):数字在排序数组中出现的次数

    剑指Offer(三十七):数字在排序数组中出现的次数 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.n ...

  6. 剑指Offer(二十七):字符串的排列

    剑指Offer(二十七):字符串的排列 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/baid ...

  7. JS 剑指Offer(四) 从尾到头打印链表

    题目:输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回). 首先定义一下链表中的节点,关于链表这个数据结构在另外一篇文章中会详细讲 function ListNode(val) { t ...

  8. [持久更新] 剑指offer题目Python做题记录

    第一题 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 思路:先快速定位到 ...

  9. 【剑指Offer】俯视50题之21 - 30题

    面试题21包括min函数的栈  面试题22栈的压入.弹出序列  面试题23从上往下打印二叉树  面试题24二叉搜索树的后序遍历序列  面试题25二叉树中和为某一值的路径  面试题26复杂链表的复制  ...

  10. 算法学习之剑指offer(四)

    题目1 题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) /** public class TreeNode { int val = 0; Tree ...

随机推荐

  1. mysql执行计划查看工具explain

    在优化sql语句时,我们经常会用到explain语句,这里对explain语句做一个详细的总结说明. The EXPLAIN statement provides information about ...

  2. jQuery操作下拉框的text值和val值

    jQuery操作下拉框的text值和val值 1,JS源码 <select name="select1" id="select1" style=" ...

  3. axure rp 8.0注册码(亲测)

    今天在看一需求原型时,发现其他部门发过来是8.0版的,老的7不能用,找了个亲测可用的验证码. License:米 业成 (STUDENT)Key:nFmqBBvEqdvbiUjy8NZiyWiRSg3 ...

  4. Linear Regression with PyTorch

    Linear Regression with PyTorch Problem Description 初始化一组数据 \((x,y)\),使其满足这样的线性关系 \(y = w x + b\) .然后 ...

  5. [c/c++] programming之路(4)、常量和变量

    一.打开多个程序(温习) #include<stdio.h> #include<stdlib.h> void main(){ ; ]; scanf("%d" ...

  6. VSCode 预览 .md 文件

    VSCode安装md插件 选择Extensions, 输入Markdown Theme Kit,下面会出现相应插件,点击install(截图中因为我已经安装,所以是设置) 或者安装插件Markdown ...

  7. bzoj 3122 随机数生成器 - BSGS

    Description Input 输入含有多组数据,第一行一个正整数T,表示这个测试点内的数据组数.   接下来T行,每行有五个整数p,a,b,X1,t,表示一组数据.保证X1和t都是合法的页码. ...

  8. Xcode project 设置相关

    FauxPas 这是一款Mac平台的用于检查Xcode项目的辅助工具 ,可以帮助我们找出常见的错误.隐藏的bug.不良实践以及可维护性问题和风格问题. 一, $(SRCROOT)  :当前工程所在的目 ...

  9. topcoder srm 500 div1

    problem1 link 如果decisions的大小为0,那么每一轮都是$N$个人.答案为0. 否则,如果答案不为0,那么概率最大的一定是一开始票数最多的人.因为这个人每一轮都在可以留下来的人群中 ...

  10. html 之 table cellpadding,cellspacing

    单元格(cell) -- 表格的内容 单元格边距(表格填充)(cellpadding) -- 代表单元格外面的一个距离,用于隔开单元格与单元格空间 单元格间距(表格间距)(cellspacing) - ...