算法题(198):数字三角形

审题:
本题需要我们找到数字三角形中的最大路径总值,并输出

思路:
方法一:动态规划

由于本题的路径权值是路径上每一个值累加起来,问题具有阶段重复性,所以我们尝试使用动态规划解决此问题

(1)定义状态表示:f[i][j]表示从起点出发到(i,j)的最大权值

(2)求导状态转移方程:
我们先从最后一步开始分析,最后一步共有两条路线到达最后的节点,那么这两条路线中权值较大的那个路线+当前节点权值就等于结果权值

即:f[i][j] = max(f[i-1][j-1],f[i-1][j]) + a[i][j]

(3)初始化

由于我们的f[i][j]计算依赖于f[i-1][j-1]和f[i-1][j],所以会有部分位置出现越界访问

图示:

左侧的所有节点都会出现越界访问情况

解决方法:从(1,1)开始记录数据与计算f数组

从(1,1)开始记录就不会出现越界访问的情况了,因为他们访问的就是外围的那一圈为0的值

第二个问题:如何确保不会将外围一圈的值当成较大权值路径去走?

我们先看数据范围,本题的数据值在0-100,所以我们初始化为0并不会让较大权值路径为外围一圈的节点。

如果题目的数据范围包含负数,那么我们就需要用最小的负数(-0x3f3f3f3f)来初始化所有值,以确保最大权值路径不会是不存在的那外围一圈

(4)填表顺序:从上至下

我们只要确保是从上到下进行计算就行,因为下一行的数据值是取决于上一行的数据值的

(5)输出答案

由于题目要求的是所有完整路径中的最大权值,所以我们最后还要遍历最后一行的所有f值,然后维护一个最大的值并输出

解题:
 

#include<iostream>
using namespace std;
const int N = 1010;
int f[N][N];//f[i][j]表示从(1,1)走到(i,j)的最大累计权值
int r,a[N][N];
int main()
{cin >> r;for (int i = 1; i <= r; i++){for (int j = 1; j <= i; j++){cin >> a[i][j];}}//状态转移方程使用for (int i = 1; i <= r; i++){for (int j = 1; j <= i; j++){f[i][j] = max(f[i - 1][j - 1], f[i - 1][j]) + a[i][j];}}//遍历最后一层的数据维护最终结果int ret = 0;for (int i = 1; i <= r; i++){ret = max(ret, f[r][i]);}cout << ret << endl;return 0;
}

P1216 [IOI 1994] 数字三角形 Number Triangles - 洛谷

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

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

相关文章

变频器实习DAY42 VF与IF电机启动方式

目录变频器实习DAY42一、工作内容1.1 OF229程序重新烧录和测试二、学习内容2.1 VF与IF电机启动方式1. VF&#xff08;Voltage Frequency&#xff09;启动电机2. IF&#xff08;Current Frequency&#xff09;启动电机总结附学习参考网址欢迎大家有问题评论交流 (* ^ ω ^)变频器…

B样条曲线,已知曲线上的某个点到起点的距离,确定这个点的参数u的值的方法

B样条曲线&#xff1a;已知弧长 L 求参数 u 的方法1. B样条曲线定义B样条曲线由以下要素定义&#xff1a;控制点&#xff1a;P₀, P₁, P₂, ..., Pₙ节点向量&#xff08; Knot Vector &#xff09;&#xff1a;U [u₀, u₁, ..., uₘ]曲线次数&#xff1a;k&#xff08;例如…

云计算学习100天-第44天-部署邮件服务器

目录 电子邮件通信——邮件服务器 基本功能 邮件通信的寻址 案例 网络架构 配置server服务器 电子邮件通信——邮件服务器 基本功能 为用户提供电子邮箱存储空间 处理用户发出的邮件——传递给收件服务器 处理用户收到的邮件——投递到邮箱 邮件通信的寻址 根据收件…

计算机视觉(七):膨胀操作

在计算机视觉中&#xff0c;膨胀是一种基本的形态学操作&#xff0c;主要用于处理和分析图像的形状。它通过“膨胀”或“放大”图像中的前景对象来增加其尺寸或连接断开的区域。 膨胀操作的工作原理类似于卷积&#xff0c;但使用的是结构元素 (structuring element)&#xff0c…

playwright+python UI自动化测试中实现图片颜色和像素对比

def compare_image(expect_path, actual_path, output_path, color_diff_threshold10.0,max_diff_pixels100):# 读取图片img1 cv2.imread(expect_path)img2 cv2.imread(actual_path)if img1.shape ! img2.shape:img2 cv2.resize(img2, (img1.shape[1], img1.shape))# ------…

企业级AI应用,Dify集成RAGFlow知识库保姆教程

第一部分&#xff1a;RAGFlow 端配置 在 Dify 能够调用之前&#xff0c;确保 RAGFlow 已经就绪并提供了可访问的 API。 步骤 1: 确保 RAGFlow 正常运行 具体可以参考&#xff1a;https://blog.csdn.net/qq_35354529/article/details/151149191?spm1001.2014.3001.5502 注意启动…

daily notes[9]

文章目录ubuntu notereferencesubuntu note Ubuntu can be written into a stick that boot ubuntu.the stick have the following effects. to install or upgrade Ubuntu include on macto experience the Ubuntu desktop without any actual operation in your OS.Disk Ut…

Java中 String、StringBuilder 和 StringBuffer 的区别?

在Java中&#xff0c;String、StringBuilder 和 StringBuffer 都用于处理字符串&#xff0c;但它们在可变性、线程安全性和性能上有显著区别。以下是它们的对比&#xff1a;1. String不可变性&#xff08;Immutable&#xff09;String 对象一旦创建&#xff0c;内容不可修改。任…

SAM TTS网页官网入口 – 在线版微软tts在线语音合成助手

SAM TTS 是一个免费好用的在线版微软语音合成助手&#xff0c;源自经典的 Windows XP 系统。它通过现代的 JavaScript 技术以在线工具的形式运行&#xff0c;让用户可以直接在线进行语音合成。SAM TTS 不仅保留了 Microsoft SAM 的标志性声音&#xff0c;还新增了更多的自定义选…

2025 大数据时代值得考的证书排名前八​

在大数据时代&#xff0c;数据处理和分析能力愈发关键&#xff0c;考取相关证书能提升职场竞争力。接下来将为大家介绍 2025 年大数据领域值得考取的证书&#xff0c;从含金量、企业认可度、就业方向和薪资等方面分析&#xff0c;助你明晰职业发展路径。CDA 数据分析师认证1、C…

浅谈linux内存管理 的RMAP机制的作用和原理

Linux 内存管理中的 RMAP 机制深度解析反向映射&#xff08;Reverse Mapping, RMAP&#xff09;是 Linux 内存管理中的核心机制&#xff0c;它解决了大型系统中内存管理的效率和扩展性问题。本解析将从作用原理、演进历史、数据结构和工作流程四个维度深入讲解。一、RMAP 核心作…

Duolingo「多邻国」v6.45.3 高级版

Duolingo「多邻国」是一款著名的语言学习应用&#xff0c;可以借助它学习西班牙语&#xff0c;法语&#xff0c;德语&#xff0c;意大利语&#xff0c;俄语&#xff0c;罗马尼亚语&#xff0c;葡萄牙语&#xff0c;土耳其语&#xff0c;荷兰语&#xff0c;爱尔兰语&#xff0c;…

【Unity Shader学习笔记】(五)Unity Shader初识

一、Shader是什么&#xff1f;Shader&#xff08;着色器&#xff09;是一段运行在GPU&#xff08;图形处理器&#xff09;上的特殊程序&#xff0c;它用于控制渲染管线的特定阶段&#xff0c;最终决定物体在屏幕上的最终颜色和效果。与传统运行在CPU上的程序不同&#xff0c;Sh…

计算机视觉与深度学习 | 双目立体特征提取与匹配算法综述——理论基础、OpenCV实践与MATLAB实现指南

===================================================== github:https://github.com/MichaelBeechan CSDN:https://blog.csdn.net/u011344545 ===================================================== 文章目录 引言 🔍 核心研究问题 理论框架 1. 相机几何模型 2. 特征提…

每青春千度硒仙人掌精粹液:从日常滴饮开始,调出好气色好体质

每天的状态&#xff0c;其实是由许多细节组成的。身体不舒服、情绪波动、气色黯淡&#xff0c;很可能都是体内节奏被打乱的信号。开始在日常中加入几滴每青春千度硒精粹液&#xff0c;是一种小小的尝试&#xff0c;慢慢发现&#xff0c;状态真的在悄悄发生改变。简单滴饮&#…

< 自用文 主机 USC 记录:> 发现正在被攻击 后的自救

环境&#xff1a; 一台 VPS&#xff0c;之前文章推荐过 $1/月 OS: Ubuntu 内存&#xff1a;961MB CPU: 1CORE 上面都是学习 Python 时写的应用&#xff0c;这些应用在 CSDN 都有原码&#xff0c;只是时间久了&#xff0c;自用的有修复bugs&#xff0c;还有些功能升级。 以前是…

硬件开发1-51单片机2-按键、中断

一、GPIO&#xff08;General Purpose Input/Output&#xff09;GPIO 是 51 单片机和外界交互最基本的方式。工作模式&#xff1a;输出模式&#xff1a;单片机给定引脚一个电平&#xff08;高电平 (5V)、低电平 (0V)&#xff09;&#xff0c;通过控制引脚实现高低电平输出。输入…

什么是Token?——理解自然语言处理中的基本单位

在日常生活中&#xff0c;我们使用手机语音助手、自动翻译软件和聊天机器人等智能工具&#xff0c;而这些技术背后都离不开对语言的精细处理。今天&#xff0c;我们就来聊聊“token”这一看似专业的术语&#xff0c;了解它在自然语言处理&#xff08;NLP&#xff09;中的重要作…

线程通信机制

目录 一、主线程与子线程基础通信 1.1 主线程向子线程传递数据 二、子线程向主线程返回数据 2.1 通过共享变量方式 2.2 同步块中使用wait/notify机制 2.3 Lock和Condition实现线程通信机制 一、主线程与子线程基础通信 1.1 主线程向子线程传递数据 通过构造函数传递参数…

硬盘 (FOREIGN) Slot:Unconfigured Bad

IBM 服务器硬盘故障&#xff0c;在webbios里看到有显示&#xff08;Foreign&#xff09;Slot:xxxx, Unconfigured Bad的硬盘&#xff0c;选中该硬盘进入属性页面在属性列表中找到“Media Error”和“Pred Fail Count”两项&#xff08;如果找不到请点击【Next】翻页&#xff09…