于动态规划的启幕之章,借 C++ 笔触绘就算法新篇

注意:代码由易到难 

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

题目链接:[IOI 1994] 数字三角形 Number Triangles - 洛谷

题目描述

观察下面的数字金字塔。

写一个程序来查找从最高点到底部任意处结束的路径,使路径经过数字的和最大。每一步可以走到左下方的点也可以到达右下方的点。

在上面的样例中,从 7→3→8→7→57→3→8→7→5 的路径产生了最大权值。

输入格式

第一个行一个正整数 �r ,表示行的数目。

后面每行为这个数字金字塔特定行包含的整数。

输出格式

单独的一行,包含那个可能得到的最大的和。

输入输出样例

输入 #1

5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5 

输出 #1

30

说明/提示

【数据范围】
对于 100%100% 的数据,1≤r≤1000,所有输入在 [0,100] 范围内。

思路:动态规划,由局部最优达到全局最优

本题属于动态规划中最优子问题类

代码一(dfs+记忆化数组) 注意:本代码有一个测试点超时

#include<iostream>  // 包含标准输入输出流库
#include<algorithm> // 包含算法库,用于使用 max 函数
using namespace std;

int r; // 全局变量,表示三角形的行数
int arr[1001][1001]; // 用于存储数字三角形的数组,大小为 1001x1001
int memory[1001][1001] = {0}; // 用于记忆化搜索的数组,初始化为 0

// 深度优先搜索(DFS)函数,用于计算从 (x, y) 到三角形底部的最大路径和
int dfs(int x, int y) {
    if (memory[x][y] != 0) return memory[x][y]; // 如果已经计算过 (x, y) 的结果,直接返回
    int mid;
    if (x > r || y > x) { // 如果超出三角形范围
        mid = 0; // 返回 0
    } else {
        // 递归计算从 (x, y) 向下和向右下两个方向的最大路径和,并加上当前节点的值
        mid = max(dfs(x + 1, y), dfs(x + 1, y + 1)) + arr[x][y];
    }
    memory[x][y] = mid; // 将结果存储到记忆化数组中
    return mid; // 返回当前节点的最大路径和
}

// 主逻辑函数,读取输入并调用 DFS
void solution() {
    cin >> r; // 输入三角形的行数
    for (int i = 1; i <= r; i++) { // 逐行读取三角形的每一行
        for (int j = 1; j <= i; j++) { // 逐个读取当前行的每个数字
            cin >> arr[i][j]; // 存储到 arr 数组中
        }
    }
    int maxSum = dfs(1, 1); // 从三角形顶部 (1, 1) 开始计算最大路径和
    cout << maxSum << endl; // 输出最大路径和
}

int main() {
    ios::sync_with_stdio(false); // 关闭同步,提高输入输出效率
    cin.tie(nullptr); // 解绑 cin 和 cout,进一步提高效率
    int T = 1; // 测试用例数量,默认为 1
    // cin >> T; // 如果需要多个测试用例,可以取消注释
    while (T--) { // 对每个测试用例调用 solution 函数
        solution();
    }
    return 0; // 程序结束
}

代码二(动态规划,通过) 

#include<iostream>
#include<algorithm>
using namespace std;

int r; // 三角形的行数
int arr[1002][1002]; // 存储输入的数字三角形
int mid[1002][1002] = {0}; // 动态规划数组,用于存储从底部到当前点的最大路径和

// 解决数字三角形问题的函数
void solution()
{
    cin >> r; // 输入三角形的行数
    for (int i = 1; i <= r; i++) // 逐行读取三角形的数据
    {
        for (int j = 1; j <= i; j++) // 每行的列数等于行号
        {
            cin >> arr[i][j]; // 输入当前元素
        }
    }

    // 动态规划从三角形的底部向上计算最大路径和
    for (int i = r; i >= 1; i--) // 从最后一行开始向上遍历
    {
        for (int j = 1; j <= i; j++) // 遍历当前行的每个元素
        {
            // 当前点的最大路径和等于当前点的值加上其下方两个点中较大的值
            mid[i][j] = max(mid[i + 1][j], mid[i + 1][j + 1]) + arr[i][j];
        }
    }
    cout << mid[1][1] << endl; // 输出从顶部到底部的最大路径和
}

int main()
{
    ios::sync_with_stdio(false); // 关闭同步,提高输入输出效率
    cin.tie(nullptr); // 解绑cin和cout,进一步提高效率
    int T = 1; // 测试用例数量(这里固定为1)
    // cin >> T; // 如果需要处理多组数据,可以取消注释
    while (T--) // 处理每一组数据
    {
        solution(); // 调用solution函数解决问题
    } 
    return 0; // 程序结束
}

代码三(动态规划+滚动数组)

#include<iostream>
#include<algorithm>
#include<cmath>
#include<iomanip>
using namespace std;
#define av(y) setprecision(y)<<fixed;

int r; // 三角形的行数
int arr[1002][1002]; // 存储输入的数字三角形
int mid[1002] = {0}; // 动态规划数组,用于存储从底部到当前点的最大路径和(一维数组)

// 解决数字三角形问题的函数
void solution()
{
    cin >> r; // 输入三角形的行数
    for (int i = 1; i <= r; i++) // 逐行读取三角形的数据
    {
        for (int j = 1; j <= i; j++) // 每行的列数等于行号
        {
            cin >> arr[i][j]; // 输入当前元素
        }
    }

    // 动态规划从三角形的底部向上计算最大路径和
    for (int i = r; i >= 1; i--) // 从最后一行开始向上遍历
    {
        for (int j = 1; j <= i; j++) // 遍历当前行的每个元素
        {
            // 当前点的最大路径和等于当前点的值加上其下方两个点中较大的值
            // 这里使用一维数组 mid 来存储中间结果
            mid[j] = max(mid[j], mid[j + 1]) + arr[i][j];
        }
    }
    cout << mid[1] << endl; // 输出从顶部到底部的最大路径和
}

int main()
{
    ios::sync_with_stdio(false); // 关闭同步,提高输入输出效率
    cin.tie(nullptr); // 解绑cin和cout,进一步提高效率
    int T = 1; // 测试用例数量(这里固定为1)
    // cin >> T; // 如果需要处理多组数据,可以取消注释
    while (T--) // 处理每一组数据
    {
        solution(); // 调用solution函数解决问题
    } 
    return 0; // 程序结束
}

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Three.js 后期处理(Post-Processing)详解

目录 前言 一、什么是后期处理&#xff1f; 二、Three.js 后期处理的工作流程 2.1 创建 EffectComposer 2.2 添加渲染通道&#xff08;Render Pass&#xff09; 2.3 应用最终渲染 三、后期处理实现示例 3.1 基础代码 四、常见的后期处理效果 4.1 辉光效果&#xf…

低代码系统-产品架构案例介绍、炎黄盈动-易鲸云(十二)

易鲸云作为炎黄盈动新推出的产品&#xff0c;在定位上为低零代码产品。 开发层 表单引擎 表单设计器&#xff0c;包括设计和渲染 流程引擎 流程设计&#xff0c;包括设计和渲染&#xff0c;需要说明的是&#xff1a;采用国际标准BPMN2.0&#xff0c;可以全球通用 视图引擎 视图…

从 HTTP/1.1 到 HTTP/3:如何影响网页加载速度与性能

一、前言 在最近使用Apipost时&#xff0c;突然注意到了http/1.1和http/2&#xff0c;如下图&#xff1a; 在我根深蒂固的记忆中&#xff0c;对于http的理解还停留在TCP协议、三次握手。由于我的好奇心&#xff0c;于是触发了我被动“开卷”&#xff0c;所以有了这篇文章&…

项目练习:重写若依后端报错cannot be cast to com.xxx.model.LoginUser

文章目录 一、情景说明二、解决办法 一、情景说明 在重写若依后端服务的过程中 使用了Redis存放LoginUser对象数据 那么&#xff0c;有存就有取 在取值的时候&#xff0c;报错 二、解决办法 方法1、在TokenService中修改如下 getLoginUser 方法中&#xff1a;LoginUser u…

C语言------二维数组指针从入门到精通

前言: 目标:需要了解及掌握数组指针的行地址、列地址、具体元素地址、具体元素地址的值是怎样定义及实现。 重点:指针的偏移,指针解引用。 难点:指针的升阶与降阶。 1. 基本概念 二维数组&#xff1a;二维数组可以看作是一个数组的数组。例如&#xff0c;int a[3][4] 表示一个 …

AI-ISP论文Learning to See in the Dark解读

论文地址&#xff1a;Learning to See in the Dark 图1. 利用卷积网络进行极微光成像。黑暗的室内环境。相机处的照度小于0.1勒克斯。索尼α7S II传感器曝光时间为1/30秒。(a) 相机在ISO 8000下拍摄的图像。(b) 相机在ISO 409600下拍摄的图像。该图像存在噪点和色彩偏差。©…

自定义数据集 ,使用朴素贝叶斯对其进行分类

代码&#xff1a; # 导入必要的库 import numpy as np import matplotlib.pyplot as plt# 定义类1的数据点&#xff0c;每个数据点是二维的坐标 class1_points np.array([[1.9, 1.2],[1.5, 2.1],[1.9, 0.5],[1.5, 0.9],[0.9, 1.2],[1.1, 1.7],[1.4, 1.1]])# 定义类2的数据点&…

蓝桥杯单片机第七届省赛

前言 这套题不难&#xff0c;相对于第六套题这一套比较简单了&#xff0c;但是还是有些小细节要抓 题目 OK&#xff0c;以上就是全部的题目了&#xff0c;这套题目相对来说逻辑比较简单&#xff0c;四个按键&#xff0c;S4控制pwm占空比&#xff0c;S5控制计时时间&#xff0…

小程序设计和开发:如何研究同类型小程序的优点和不足。

一、确定研究目标和范围 明确研究目的 在开始研究同类型小程序之前&#xff0c;首先需要明确研究的目的。是为了改进自己的小程序设计和开发&#xff0c;还是为了了解市场趋势和用户需求&#xff1f;不同的研究目的会影响研究的方法和重点。例如&#xff0c;如果研究目的是为了…

反向代理模块jmh

1 概念 1.1 反向代理概念 反向代理是指以代理服务器来接收客户端的请求&#xff0c;然后将请求转发给内部网络上的服务器&#xff0c;将从服务器上得到的结果返回给客户端&#xff0c;此时代理服务器对外表现为一个反向代理服务器。 对于客户端来说&#xff0c;反向代理就相当…

一文讲解HashMap线程安全相关问题

HashMap不是线程安全的&#xff0c;主要有以下几个问题&#xff1a; ①、多线程下扩容会死循环。JDK1.7 中的 HashMap 使用的是头插法插入元素&#xff0c;在多线程的环境下&#xff0c;扩容的时候就有可能导致出现环形链表&#xff0c;造成死循环。 JDK 8 时已经修复了这个问…

oracle:子查询

子查询: 一条查询语句中嵌入了另一条查询语句, 被嵌入里面的这条查询语句称为子查询, 外面的查询语句称为主查询 子查询的分类 相关性子查询&#xff08;Correlated Subquery&#xff09;是指子查询的执行依赖于外部查询的每一行数据。也就是说&#xff0c;子查询会对外部查询…

AI技术在SEO关键词优化中的应用策略与前景展望

内容概要 在数字营销的快速发展中&#xff0c;AI技术逐渐成为SEO领域的核心驱动力。其通过强大的数据分析和处理能力&#xff0c;不仅改变了我们优化关键词的方式&#xff0c;也提升了搜索引擎优化的效率和效果。在传统SEO中&#xff0c;关键词的选择与组合常依赖人工经验和直…

Java项目: 基于SpringBoot+mybatis+maven+mysql实现的疫苗发布和接种预约管理系统(含源码+数据库+开题报告+毕业论文)

一、项目简介 本项目是一套基于SpringBootmybatismavenmysql疫苗发布和接种预约管理系统 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#xff0c;eclipse或者idea 确保可以运行&#xff01; 该系统功能完善、…

VSCode中快速创建Html文件

1、下载并安装好VSCode软件&#xff0c;启动软件。 2、依次点击左上角选项卡“file”-“New File”。 输入文件名称后缀&#xff0c;如&#xff1a;HelloWorld.html。 选择新建文件的目录所在位置。 3、HelloWorld.html中输入英文格式的!&#xff0c;按回车键后会默认依据…

CMake项目编译与开源项目目录结构

Cmake 使用简单方便&#xff0c;可以跨平台构建项目编译环境&#xff0c;尤其比直接写makefile简单&#xff0c;可以通过简单的Cmake生成负责的Makefile文件。 如果没有使用cmake进行编译&#xff0c;需要如下命令&#xff1a;&#xff08;以muduo库echo服务器为例&#xff09;…

网络原理(4)—— 网络层详解

目录 一. IP协议报头结构 二. 地址管理 2.1 路由器 2.1.1 路由选择 2.1.2 WAN口&#xff08;Wide Area Network&#xff09; 2.1.3 LAN口&#xff08;Local Area Network&#xff09; 2.1.4 WLAN口&#xff08;Wireless Local Area Network&#xff09; 2.2 网段划分…

Hot100之图论

200岛屿数量 题目 思路解析 把访问过的格子插上棋子 思想是先污染再治理&#xff0c;我们有一个inArea&#xff08;&#xff09;函数&#xff0c;是判断是否出界了 我们先dfs&#xff08;&#xff09;放各个方向遍历&#xff0c;然后我们再把这个位置标为0 我们岛屿是连着…

【HarmonyOS之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(三)

目录 1 -> 生命周期 1.1 -> 应用生命周期 1.2 -> 页面生命周期 2 -> 资源限定与访问 2.1 -> 资源限定词 2.2 -> 资源限定词的命名要求 2.3 -> 限定词与设备状态的匹配规则 2.4 -> 引用JS模块内resources资源 3 -> 多语言支持 3.1 -> 定…

Python从零构建macOS状态栏应用(仿ollama)并集成AI同款流式聊天 API 服务(含打包为独立应用)

在本教程中,我们将一步步构建一个 macOS 状态栏应用程序,并集成一个 Flask 服务器,提供流式响应的 API 服务。 如果你手中正好持有一台 MacBook Pro,又怀揣着搭建 AI 聊天服务的想法,却不知从何处迈出第一步,那么这篇文章绝对是你的及时雨。 最终,我们将实现以下功能: …