动态规划——数字三角形模型

news2024/12/28 10:02:51

数字三角形模型:

给定一个如下图所示的数字三角形,从顶部出发,在每一结点可以选择移动至其左下方的结点或移动至其右下方的结点,一直走到底层,要求找出一条路径,使路径上的数字的和最大。

输入格式:

第一行包含整数 n,表示数字三角形的层数。

接下来 n 行,每行包含若干整数,其中第 i 行表示数字三角形第 i 层包含的整数。

输出格式:

输出一个整数,表示最大的路径数字和。

思路:

对于三角形中的每个点,如果我们走到了该点,那么路径中该点的上一个点一定是左上角的点或者是右上角的点。那么该点的状态一定可以由左上右上两个点的状态推导得到。

从集合的角度考虑:如果将所有走到(i,j)点的路径看做是一个集合,那么该集合可以不重不漏的划分为从左上角走到(i,j)的路径和从右上角走到(i,j)的路径这两个集合。我们要取集合中的最大值,所以取划分出的两个集合中的最大值即可。

f[i][j]表示走到(i,j)点的路径中的最大值,a[i][j]表示(i,j)位置的值。

状态转移方程如下:

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

因为终点在最后一行,所以我们在三角形的最后一行中寻找最大值即可。

注意这里有边界的问题:我们要保证左上的点和右上的点没有越界才走,并且必须要选择一个点。所以我们可以选着将所有点的初始状态取INF,特别的f[1][1]=g[1][1]。

数字三角形问题一般求的是最大/小值,一般都有边界问题,在更新边界上的值得时候不要被边界外的值影响。

代码如下:

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

const int N = 510;
int g[N][N], f[N][N];//三角形,以每个点为终点的路径的最大值
int n;

int main() {
    cin >> n;
    for (int i = 1; i <= n; i++)//读入地图(其实可以在读入的时候就处理,这里将读入和处理分开了)
        for (int j = 1; j <= i; j++)
            cin >> g[i][j];

    memset(f, -0x3f, sizeof f);//初始化
    f[1][1] = g[1][1];

    for (int i = 1; i <= n; i++)
        for (int j = 1; j <= i; j++) {
            if (j - 1 >= 1)f[i][j] = max(f[i][j], f[i - 1][j - 1] + g[i][j]);//如果左上角未越界
            if (j < n)f[i][j] = max(f[i][j], f[i - 1][j] + g[i][j]);//如果右上角未越界
        }

    int res = -0x3f3f3f3f;//在最后一行中找最大值
    for (int i = 1; i <= n; i++)res = max(res, f[n][i]);

    cout << res;
    return 0;
}

例题:

1.摘花生

Hello Kitty想摘点花生送给她喜欢的米老鼠。

她来到一片有网格状道路的矩形花生地(二维矩阵),从西北角进去,东南角出来。

地里每个道路的交叉点上都有种着一株花生苗,上面有若干颗花生,经过一株花生苗就能摘走该它上面所有的花生。

Hello Kitty只能向东或向南走,不能向西或向北走。

问Hello Kitty最多能够摘到多少颗花生。

输入格式:

第一行是一个整数T,代表一共有多少组数据。

接下来是T组数据。

每组数据的第一行是两个整数,分别代表花生苗的行数R和列数 C。

每组数据的接下来R行数据,从北向南依次描述每行花生苗的情况。每行数据有C个整数,按从西向东的顺序描述了该行每株花生苗上的花生数目M。

输出格式:

对每组输入数据,输出一行,内容为Hello Kitty能摘到得最多的花生颗数。

思路:

每个点的状态由右边或者是上边的点转移得到。

状态转移方程:

f[i][j] = max(f[i - 1][j], f[i][j - 1]) + g[i][j]

代码如下:

#include<iostream>
using namespace std;

const int N = 1010;
int f[N][N];
int T, n, m;

int main() {
    cin >> T;

    while (T--) {
        cin >> n >> m;

        for (int i = 1; i <= n; i++)
            for (int j = 1; j <= m; j++) {
                cin >> f[i][j];
                f[i][j] = max(f[i - 1][j], f[i][j - 1]) + f[i][j];
            }

        cout << f[n][m] << endl;
    }

    return 0;
}

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

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

相关文章

力扣 895. 最大频率栈

题目 设计一个类似堆栈的数据结构&#xff0c;将元素推入堆栈&#xff0c;并从堆栈中弹出出现频率最高的元素。 实现 FreqStack 类: FreqStack() 构造一个空的堆栈。 void push(int val) 将一个整数 val 压入栈顶。 int pop() 删除并返回堆栈中出现频率最高的元素。 如果出现…

傻妞旧版本(合集)

目录一、前言二、下载三、新版傻妞订阅合集一、前言 傻妞旧版本(合集),包含amd和arm版本 二、下载 &#x1f170;️amd✅还未大改&#xff0c;init web未出 &#x1f534;[sillyGirl_amd_2022-08-05] ➡️百度网盘 ➡️天翼云盘&#xff08;访问码&#xff1a;ha8s&#xff09…

如何开通小程序?开通小程序要钱吗?

关于如何开通小程序&#xff1f;开通小程序要钱吗&#xff1f;这两个问题&#xff0c;今天给大家做一个简单的解答。 一、如何开通小程序&#xff1f; “开通小程序”这个说法其实并不准确&#xff0c;能开通的是小程序账号&#xff0c;开通完小程序账号后还需要去制作小程序&…

计算机视觉之目标检测训练数据集(皮卡丘)《2》

在做目标检测&#xff0c;训练数据集的时候&#xff0c;可以先看前段时间的一篇基础文章&#xff1a;计算机视觉之目标检测(object detection)《1》https://blog.csdn.net/weixin_41896770/article/details/128062645先熟悉一些基本知识&#xff0c;如&#xff1a;锚框&#xf…

『.NET』.Net Core在Linux中生成验证码的实现封装

&#x1f4e3;读完这篇文章里你能收获到 .Net跨平台在Linux中及Windows中都可生成验证码两套已验证过的实现方案代码封装&#xff0c;即Copy即用快速在Centos 7.x中安装Linux字体 文章目录一、安装Linux字体1. 查看字体库2. 运行安装字体库3. 安装ttmkfdir4. 查看字体库是否已…

搜索技术——模拟退火算法

如果有兴趣了解更多相关内容&#xff0c;欢迎来我的个人网站看看&#xff1a;瞳孔空间 一&#xff1a;算法及模型 物理退火过程 什么是退火&#xff1a;是指将固体加热到足够高的温度&#xff0c;使分子呈随机排列状态&#xff0c;然后逐步降温使之冷却&#xff0c;最后分子…

SPECjvm 2008 小记

背景 specjvm2008是免费的&#xff0c;直接官网下载就可以开跑了。但俗话说的好&#xff0c;便宜无好货&#xff0c;没啥厂家买账&#xff0c;看官网列出的成绩公示结果&#xff0c;根本没几家上传成绩。 另外&#xff0c;SPECjvm2008本身是测试JRE的执行成绩&#xff0c;也就…

Android databinding之RecycleView使用与介绍(二)

一 、介绍 通过上一篇databinding接入&#xff0c;我们已大概了解到databinding接入的流程和数据的简单绑定。 如果你刚看这边&#xff0c;并不了解databinding的使用&#xff0c;可以查看&#xff1a;Android databinding的接入使用与详解(一) Activity和fragment的数据绑定…

左(6)hash,大数据,位运算

前言 仅记录学习笔记&#xff0c;如有错误欢迎指正。 一、哈希函数和哈希表&#xff1a; hash()&#xff1a; (1) 输入是无限的&#xff0c;输出有限&#xff01; (2)相同的输入&#xff0c;相同的输出&#xff08;无随机因子&#xff09; (3)不同的输入&#xff0c;也可能相…

jQuery 语法

通过 jQuery&#xff0c;您可以选取&#xff08;查询&#xff0c;query&#xff09; HTML 元素&#xff0c;并对它们执行"操作"&#xff08;actions&#xff09;。 jQuery 语法 jQuery 语法是通过选取 HTML 元素&#xff0c;并对选取的元素执行某些操作。 基础语法…

【Python教学】pyqt6入门到入土系列,超详细教学讲解

一、什么是PyQt6? 简单介绍一下PyQt6 1、基础简介 PyQt6 Digia 公司的 Qt 程序的 Python 中间件。Qt库是最强大的GUI库之一。PyQt6的官网&#xff1a;www.riverbankcomputing.co.uk/news。PyQt6是由Riverbank Computing公司开发的 资料大礼包点击蓝色字体领取 Python零基础…

机器学习6scikit-learn中的scaler

文章目录一、scikit-learn中的scaler对测试数据集如何归一化&#xff1f;测试数据是模拟真实环境&#xff1a;综上二、演示一、scikit-learn中的scaler 对测试数据集如何归一化&#xff1f; 测试数据集不能跟训练数据集归一化一样&#xff0c;应该把测试数据集与训练数据集归…

Java JDK 环境变量配置教程

文章目录Java JDK 环境变量配置JDK 11 环境变量配置详细步骤Java JDK 环境变量配置 环境变量&#xff08;environment variables&#xff09;一般是指在操作系统中用来指定操作系统运行环境的一些参数&#xff0c;如&#xff1a;临时文件夹位置和系统文件夹位置等。 环境变量…

第二证券|抖音发布三季度安全透明度报告,整治贩卖焦虑广告近3万条

近来&#xff0c;抖音发布《2022年第三季度安全透明度陈述》(以下简称《陈述》)。《陈述》显现经过要点整治&#xff0c;渠道不标准表达削减超越30%&#xff0c;不实信息被告发量同比下降36.7%&#xff0c;整治贩卖焦虑广告2.9万条。一起&#xff0c;抖音还更新了《社区自律条约…

关于我对线程安全问题中死锁的理解

文章目录1.什么是死锁2.三个典型情况3.可重入与不可重入4.死锁的四个必要条件5.如何破除死锁1.什么是死锁 比如张三谈了一个女朋友&#xff0c;张三就对这个女朋友加锁了。 此时李四也看上了这个女生&#xff0c;但是他只能等待张三分手&#xff08;解锁&#xff09;后&#xf…

[附源码]计算机毕业设计保护濒危动物公益网站Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

赋能千百行加快 “5G+工业互联网”落地深耕

目前&#xff0c;我国5G基站已达196.8万个&#xff0c;“5G工业互联网”建设项目3100个&#xff0c;5G与工业互联网融合应用深入工业设计、制造、管理、服务等各环节&#xff0c;在促进传统企业提质降本增效的同时&#xff0c;不断拓展信息通信产业新蓝海。 记者从工信部获悉&a…

Nginx部署Vue前端项目

系统环境&#xff1a;Mac Pro—10.15.7版本 Nginx版本&#xff1a;1.19.6 一、安装Nginx brew install nginx 1、安装完成 Nginx的配置文件目录&#xff1a;/usr/local/etc/nginx Nginx的安装目录&#xff1a;/usr/local/Cellar/nginx 2、启动Nginx brew services star…

Linux虚拟机共享文件夹不显示问题终极解决方法

打开共享文件夹处查看一下&#xff0c;我的结果如下图&#xff08;没有显示共享文件内容&#xff09;&#xff1a; 接着打开终端&#xff1a; 输入命令&#xff1a;没有共享目录显示 解决方法&#xff1a; 输入&#xff1a;sudo apt-get install open-vm-tools 等待安装完 …

音乐在线教育解决方案,打造在线教育高品质教学体验

音乐是一种在时间中流动的形态&#xff0c;有节奏的音乐&#xff0c;能给人带来心理的快乐和艺术的享受&#xff0c;学一门乐器成为了很多人的选择。因此&#xff0c;音乐教育培训机构在搭建线上音乐课程时&#xff0c;就需要选择低延时、高同步、画质还原、高保真的技术方案&a…