动态规划数字三角形模型——AcWing 1015. 摘花生

动态规划数字三角形模型

定义

动态规划数字三角形模型是在一个三角形的数阵中,通过一定规则找到从顶部到底部的最优路径或最优值。

运用情况

通常用于解决具有递推关系、需要在不同路径中做出选择以达到最优结果的问题。比如计算最短路径、最大和等

注意事项

  • 正确定义状态表示,确保能涵盖所有可能情况且无冗余。
  • 注意边界条件的处理。
  • 确保递推关系的正确性和完整性。

解题思路

  • 确定状态:一般是用一个二维数组来表示在某个位置时的最优值。
  • 建立递推关系:根据问题的具体要求,找到从上层到下层每个位置的最优值与之前位置的关系。
  • 从顶部开始逐步计算,根据递推关系更新状态,最终得到底部的最优解。

例如,在一个数字三角形中,要求从顶部到底部路径上数字之和最大。则状态可以定义为 dp[i][j]表示到达第 i 行第 j 列位置时的最大和,递推关系可能是 dp[i][j] = max(dp[i-1][j-1], dp[i-1][j]) + triangle[i][j]。通过从顶部向下依次计算状态,最终得到底部的最大和。

AcWing 1015. 摘花生

题目描述

1015. 摘花生 - AcWing题库

运行代码

#include <iostream>
#include <cstring>
using namespace std;
int dp[101][101];
int main() {int T;cin >> T;while (T--) {int R, C;cin >> R >> C;for (int i = 1; i <= R; i++) {for (int j = 1; j <= C; j++) {cin >> dp[i][j];}}for (int i = 1; i <= R; i++) {for (int j = 1; j <= C; j++) {dp[i][j] += max(dp[i - 1][j], dp[i][j - 1]);}}cout << dp[R][C] << endl;}return 0;
}

代码思路

  • 定义一个二维数组 dp[101][101] 来存储在每个位置能获得的最大花生数。
  • 对于输入的每组数据,先读取花生苗的行数 R 和列数 C,以及每行每列花生苗上的花生数量并存储到数组中。
  • 然后通过两个嵌套的循环遍历整个花生地。在每个位置 (i, j) ,通过比较从上方 (i - 1, j) 位置过来的最大花生数和从左方 (i, j - 1) 位置过来的最大花生数,取较大值加上当前位置的花生数,更新该位置的 dp[i][j] ,这就体现了动态规划的思想,即每个位置的最优值是基于之前已计算位置的最优值得到的。
  • 当遍历完整个花生地后,最后一行最后一列的 dp[R][C] 就是从西北角到东南角能摘到的最多花生数,输出即可。

改进思路

  1. 空间优化:可以观察到在计算过程中,实际上只需要当前行和上一行的信息,所以可以通过滚动数组的方式来减少空间复杂度,只使用两行的空间来进行计算。
  2. 输入优化:可以考虑对输入数据的读取进行一些优化,比如使用更快的输入流或采用更高效的输入处理方式。
  3. 异常处理:可以添加一些对输入数据合法性的检查和异常处理机制,以应对可能出现的不合法输入情况。

其它代码

#include <iostream>
#include <cstring>
using namespace std;
void run()
{int a[110][110], f[110][110];memset(a, 0, sizeof a);memset(f, 0, sizeof f);int r, c;cin >> r >> c;for(int i = 1; i <= r; i ++)for(int j = 1; j <= c; j ++)cin >> a[i][j];for(int i = 1; i <= r; i ++)for(int j = 1; j <= c; j ++)f[i][j] = max(f[i][j - 1], f[i - 1][j]) + a[i][j];cout << f[r][c] << endl;
}
int main()
{int t;cin >> t;while(t--) run();return 0;
}

代码思路

  • run 函数中:
    • 定义了两个二维数组 a 用于存储花生地中每个位置的花生数量,f 用于存储到达每个位置的最大花生数。
    • 通过 memset 对两个数组进行初始化清零。
    • 读取花生地的行数 r 和列数 c,并输入每个位置的花生数量到 a 中。
    • 然后通过两层循环,在每个位置 (i, j) ,通过比较从左边 (i, j - 1) 和上边 (i - 1, j) 过来的最大花生数,取较大值加上当前位置的花生数,更新 f[i][j],这体现了动态规划的递推过程。最后输出右下角 f[r][c] 的值,即从西北角到东南角能获取的最大花生数。
  • 在 main 函数中,读取测试用例的数量 t,然后逐个调用 run 函数进行处理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/34692.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java —— 网络编程(TCP)

网络编程三要素&#xff1a;IP&#xff0c;端口号&#xff0c;协议。 一、连接 客户端使用 Socket 类&#xff1a; Socket snew Socket(目标主机IP&#xff0c;端口号); 服务器端使用 ServerSocket 类&#xff1a; ServerSocket ssnew ServerSocket(端口号); Socket sss.…

【SAP HANA 35】HANA窗口函数PARTITION BY示例

窗口函数允许对数据进行高级分析和计算&#xff0c;例如排名和累计和。 -- 计算每个员工在其职位组中的工资排名 SELECTFirstName,LastName,Position,Salary,RANK() OVER (PARTITION BY FirstName,LastName ORDER BY Salary DESC) AS Rank FROM Employees;-- 计算每个员工在其…

TXL编程语言环境安装

TXL&#xff08;Tree Transformation Language&#xff09;是一种专门用于源代码分析和转换的编程语言。它基于树形结构&#xff0c;可以帮助开发人员进行各种代码重构、代码生成、语法转换等操作。TXL具有强大的模式匹配和模式替换功能&#xff0c;因此在软件工程和编程语言研…

new和delete操作符的作用以及与malloc和free进行比较

new 和 delete 是在C中用于动态内存分配和释放的操作符&#xff0c;而 malloc 和 free 则是在C语言&#xff08;以及C中作为C的兼容部分&#xff09;中用于相同目的的函数。以下是它们各自的作用以及它们之间的比较&#xff1a; new 和 delete 作用&#xff1a; new&#xf…

速盾:DDOS能打死高防ip吗?

DDoS攻击是一种利用大量计算机或设备发起的分布式拒绝服务攻击。它的目标是通过发送大量流量或请求&#xff0c;使目标服务器或网络资源无法正常工作。高防IP是一种具有强大防御能力的网络服务&#xff0c;能够抵御各种形式的网络攻击&#xff0c;包括DDoS攻击。然而&#xff0…

英文输入法(75%用例)C卷(JavaPythonC++Node.jsC语言)

主管期望你来实现英文输入法单词联想功能。需求如下: 依据用户输入的单词前缀,从已输入的英文语句中联想出用户想输入的单词,按字典序输出联想到的单词序列,如果联想不到,请输出用户输入的单词前缀。 注意: 1. 英文单词联想时,区分大小写 2. 缩略形式如”dont”,…

机器学习-线性回归模型python demo

文章目录 前言机器学习-线性回归模型python demo1. 准备工作2. 实施2.1. 准备样本数据2.2. 创建线性回归模型2.3. 预测新的房价 3. 散点图、线形图 完整demo 前言 如果您觉得有用的话&#xff0c;记得给博主点个赞&#xff0c;评论&#xff0c;收藏一键三连啊&#xff0c;写作不…

【Python】已解决:Python读取字典查询键报错“KeyError: ‘d‘”

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决&#xff1a;Python读取字典查询键报错“KeyError: ‘d’” 一、分析问题背景 在Python编程中&#xff0c;字典&#xff08;dictionary&#xff09;是一种非常重要的数据结构…

要在服务器上部署SSM(Spring, Spring MVC, MyBatis的组合

首先需要一台运行Ubuntu的服务器。下面是如何下载和安装Ubuntu的步骤&#xff1a; 一、下载Ubuntu ISO镜像 1. 访问Ubuntu官方网站&#xff1a; • 打开浏览器&#xff0c;进入Ubuntu的官方网站。 • 选择适合的Ubuntu版本下载&#xff0c;一般选择LTS&#xff08;长期支持版…

静态内部类局部内部类

静态内部类 创建静态内部类对象的格式&#xff1a;外部类名.内部类名 对象名new外部类名.内部类名&#xff08;&#xff09;; 调用非静态方法的格式&#xff1a;先创建对象&#xff0c;用对象调用 调用静态方法的格式&#xff1a;外部类名.内部类名.方法名&#xff08;&#…

JAVA学习-练习试用Java实现“三数之和”

问题&#xff1a; 给定一个包含 n 个整数的数组 nums&#xff0c;判断 nums 中是否存在三个元素 a&#xff0c;b&#xff0c;c &#xff0c;使得 a b c 0 &#xff1f;请你找出所有和为 0 且不重复的三元组。 注意&#xff1a;答案中不可以包含重复的三元组。 示例 1&…

GMSB文章一:介绍

欢迎大家关注全网生信学习者系列&#xff1a; WX公zhong号&#xff1a;生信学习者Xiao hong书&#xff1a;生信学习者知hu&#xff1a;生信学习者CDSN&#xff1a;生信学习者2 Lin, Huang, et al. [lin2024effect]&#xff0c;本文的研究重点是探讨性行为对HIV-1血清转换的影…

【笔记】echarts图表的缩放和鼠标滚动的处理解决方案

解决方案不是很好&#xff0c;来源于github的issue&#xff0c;官方提供了&#xff0c;组合键触发缩放的功能。 https://github.com/apache/echarts/issues/5769 https://echarts.apache.org/zh/option.html#dataZoom-inside.zoomOnMouseWheel dataZoom-inside.zoomOnMouseWhe…

面试-细聊synchronized

1.线程安全问题的主要诱因&#xff1a; 存在多条共享数据(临界资源) 存在多条线程共同操作这些共享数据 解决问题的根本方法&#xff1a; 同一时刻有且仅有一个线程在操作共享数据&#xff0c;其他线程必须等到该线程处理完数据后在对共享数据进行操作。 2.synchroized锁 分…

【DFS】个人练习-Leetcode-LCS 03. 主题空间

题目链接&#xff1a;https://leetcode.cn/problems/YesdPw/description/ 题目大意&#xff1a;二位字符数组grid[][]&#xff0c;0代表走廊&#xff0c;其他字符代表某种type的房间。上下左右连续的同type的房间被视为同一块区域。grid[][]边缘的房间也视为和走廊相接&#x…

C++三大特性之一:多态

一、多态 1、通过指针创建对象&#xff08;动态分配&#xff09; #include <iostream> using namespace std;class Base { public:virtual void show() {cout << "Base class show" << endl;} };class Derived : public Base { public:void show…

Java中的设计模式实战指南

Java中的设计模式实战指南 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 引言 设计模式是软件开发中常用的解决方案模板&#xff0c;它们提供了一种可复用的…

Python学习笔记18:进阶篇(七)常见标准库使用之OS模块

前言 入门到进阶的知识点基本都学习了&#xff0c;可能有一些遗漏的请谅解&#xff0c;不过只要坚持学习下去&#xff0c;在后面的学习中进行查缺补漏。 根据Python crash course书中的进度&#xff0c;要准备开始写小项目了。在这之前&#xff0c;我看了Python的官方教程&am…

房产平台系统小程序源码

&#x1f3e0; 一键解锁购房新体验 &#x1f513; 房产小程序 实现前端 发布二手房 租房 商品 求租 求购等信息&#xff1b; 后台发布 新房&#xff0c;二手房租房 商品 写字楼 求租求购等房源信息&#xff1b; 功能完善的一块房产小程序 &#x1f31f; 房产平台小程序的魅力…

第二证券:港交所上市24周年 市值增长38倍

香港交易及结算所有限公司&#xff08;下称香港交易所&#xff09;于近来举办庆典活动&#xff0c;庆祝上市24周年。 据介绍&#xff0c;自2000年起&#xff0c;香港交易所逐步发展成为全球领先的商场营运机构&#xff0c;也成为连接中国内地与国际商场的主要桥梁。到2024年6月…