《剑指offer》第四十七题(礼物的最大价值)
// 面试题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》第四十七题(礼物的最大价值)的更多相关文章
- 《剑指offer》第二十七题(二叉树的镜像)
// 面试题27:二叉树的镜像 // 题目:请完成一个函数,输入一个二叉树,该函数输出它的镜像. #include <iostream> #include "BinaryTree ...
- 《剑指offer》第十七题(打印1到最大的n位数)
// 面试题17:打印1到最大的n位数 // 题目:输入数字n,按顺序打印出从1最大的n位十进制数.比如输入3,则 // 打印出1.2.3一直到最大的3位数即999. #include <ios ...
- 《剑指offer》面试题47. 礼物的最大价值
问题描述 在一个 m*n 的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于 0).你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格.直到到达棋盘的右下角.给定一个棋盘及 ...
- 剑指offer第四章
剑指offer第四章 1.二叉树的镜像 二叉树的镜像:输入一个二叉树,输出它的镜像 分析:求树的镜像过程其实就是在遍历树的同时,交换非叶结点的左右子结点. 求镜像的过程:先前序遍历这棵树的每个结点,如 ...
- 剑指Offer(三十七):数字在排序数组中出现的次数
剑指Offer(三十七):数字在排序数组中出现的次数 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.n ...
- 剑指Offer(二十七):字符串的排列
剑指Offer(二十七):字符串的排列 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/baid ...
- JS 剑指Offer(四) 从尾到头打印链表
题目:输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回). 首先定义一下链表中的节点,关于链表这个数据结构在另外一篇文章中会详细讲 function ListNode(val) { t ...
- [持久更新] 剑指offer题目Python做题记录
第一题 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 思路:先快速定位到 ...
- 【剑指Offer】俯视50题之21 - 30题
面试题21包括min函数的栈 面试题22栈的压入.弹出序列 面试题23从上往下打印二叉树 面试题24二叉搜索树的后序遍历序列 面试题25二叉树中和为某一值的路径 面试题26复杂链表的复制 ...
- 算法学习之剑指offer(四)
题目1 题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) /** public class TreeNode { int val = 0; Tree ...
随机推荐
- centos7开放及查看端口
centos7中的防火墙改成了firewall,使用iptables无作用,开放端口的方法如下: firewall-cmd --zone=public --add-port=80/tcp --perm ...
- mysql引擎和事务
对于应用程序和用户来说,同样一张表的数据无论用什么引擎来存储,看到的数据都是一样的,只是不同的引擎在功能.占用空间大小.读取性能等方面可能有所差别. mysql最常用的存储引擎为Innodb.MyIS ...
- MySQL 常用使用语句
1)批量删除表 Select CONCAT( 'drop table ', table_name, ';' ) FROM information_schema.tables Where table_n ...
- Wxpython零基础制作计算器
本文关于Wxpython零基础利用python3.6在pycharm下制作计算器,文章末尾有免费源代码供下载 以后同步更新到博客园和这个网站,www.empirefree.top, 这个网站备案号没有 ...
- mysqldump: Couldn't execute 'SHOW VARIABLES LIKE 'ndbinfo_version'': Native table 'performance_schema'.'session_variables' has the wrong structure (1682)
centos7.5 导出整个数据库报错 问题: [root@db01 ~]# mysqldump -uroot -pBgx123.com --all-databases --single-transa ...
- topcoder srm 710 div1 -23
1.给定两个长度都为$n$的数组$A,B$,给出一个操作序列将$A$变成$B$.每个操作可以是以下两种之一:(1)选择一个$i,0\leq i <n$且$A_{i} \neq 0$,令$t=A_ ...
- ODAC(V9.5.15) 学习笔记(三)TOraSession(2)
2. 事务相关 名称 类型 说明 AutoCommit Boolean 是否自动提交事务 注意:只有当TOraSession和TOraQuery的AutoCommit都为True时才对每个数据库操作自 ...
- Delphi程序的主题(Theme)设置
本文参考了 http://superlevin.ifengyuan.tw/delphi-change-vcl-style/ 在项目的工程文件中勾选主题,设置缺省主题为Windows 部分代码如下: u ...
- MongDB 数据库使用技巧及注意事项
说明 本文记录MongoDB数据库的使用技巧总结,特性发现. 利用TTL特性实现数据定时删除 限制: 你不能创建TTL索引,如果要索引的字段已经在其他索引中使用. 索引不能包含多个字段. 索引的字段必 ...
- P3178 [HAOI2015]树上操作
P3178 [HAOI2015]树上操作 思路 板子嘛,其实我感觉树剖没啥脑子 就是debug 代码 #include <bits/stdc++.h> #define int long l ...