动态规划(简单习题)

数字三角形 Number Triangles


首先我看到这个题目就在思考应该用怎样一个数据结构来存放这些数据,是二叉树,还是并查集那样的连接。
第二个问题这个使用动态规划应该怎样构建状态转移方程,使用dfs来遍历然后使用一个数组来存放最大价值吗? 

针对第一个问题我们竟然要使用一个二维数组来存放(是我想复杂了,直接用二维数组来存就好了,应为下一层判断大打谁小然后再直接放进去就可以了)

思路一:从下而上

从倒数第二层开始,将每个下一层相邻的两个数分别与这个数进行相加,然后使用max函数判断那个大,那个大这个数就存下这个数 其状态转移方程就是dp[i][j]+=max(dp[i+1][j],dp[i+1][j+1]);(需要注意的是我的这个是自加,第一次写就是没有自加导致的错误)

这个思路值得学习的地方就是:第一使用了二维数组进行存放了数据,第二就是从下而上。

代码如下:

#include<iostream>
#include<algorithm>
using namespace std;
const int N=1000+10;
int dp[N][N];
int main()
{int n;cin>>n;for(int i=1;i<=n;i++){for(int j=1;j<=i;j++){cin>>dp[i][j];}}for(int i=n-1;i>=1;i--){for(int j=1;j<=i;j++){dp[i][j]+=max(dp[i+1][j],dp[i+1][j+1]);//这里是自加}}cout<<dp[1][1]<<endl;//那么最后开头的数就是最大的数return 0;
}

思路二:使用dfs(虽然这个时间会爆,但是可以复习一下dfs)自上而下

我看题解定义的dfs函数都是使用int类型来定义的,但是由于我写dfs函数的时候常常用void类型,所以我就是使用void类型来写一个dfs函数的思路吧。

首先就是考虑使用那种数据结构来存放数据,这里还是使用一个二维数组来存放数据,这个dfs函数终止条件就是当检查到最后一层的就可以停止了,但是实际上是要比最后一层,多一层但是说句实话我现在一般这种退出条件都是试出来的,我具体也不知道是怎么得出来的。

其实这里是不需要一个检查是否已经走过的检查数组,因为方向都是向下的,不会出现返祖现象,所以可以不需要vis数组,节省空间

代码如下:

#include<iostream>
#include<algorithm>
using namespace std;
const int N=1000+10;
int dp[N][N];
//int vis[N][N];
int maxN=-1;
int n;
void dfs(int x,int y,int sum)
{if(x>=n+1){maxN=max(maxN,sum);return ;}
//	if(vis[x][y]==1)
//	return ;
//	vis[x][y]=1;dfs(x+1,y,sum+dp[x][y]);dfs(x+1,y+1,sum+dp[x][y]);
//	vis[x][y]=0;return ;
}
int main()
{cin>>n;for(int i=1;i<=n;i++){for(int j=1;j<=i;j++){cin>>dp[i][j];}}dfs(1,1,0);cout<<maxN<<endl;return 0;
}

疯狂的采药

 这是一个非常典型的完全背包问题,好了那么问题就来了,01背包和完全背包的区别是什么?
01背包对所有物品只能取一次,而完全背包所有物品可以取无限次。那么怎么体现这个区别呢?
01背包每次取最优解都是在上行中,所以在状态转移方程中取最优时是dp[j],而在01背包中是dp[j-1],这个就是完全背包和01背包的区别。
  关于背包问题还有值得注意的是最后的取值是下标为背包容量最大的时候。

代码如下

#include<iostream>
#include<algorithm>
using namespace std;
const int N=100000;
const int M=1e7+10;
unsigned long long dp[M];
unsigned long long w[N];
unsigned long long v[N];
unsigned long long sum=0,n;
int main()
{cin>>sum>>n;for(int i=1;i<=n;i++){cin>>w[i]>>v[i];}for(int i=1;i<=n;i++){for(int j=w[i];j<=sum;j++){dp[j]=max(dp[j],dp[j-w[i]]+v[i]);//如果是01背包问题那么就是max(dp[j-1],dp[j-w[i]]+v[i])}}cout<<dp[sum];//无论是01背包还是完全背包 最后的答案都是取容量最大的时候return 0;
}

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

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

相关文章

wps 365 批量修改.xlsx、.xls,单元格内容的格式为yyyy-mm-dd

xlsx、xls文件导入校验单元格内容格式有误&#xff0c;批量修改步骤如下 1.选中要修改内容的单元格列 2.选择数据-分列-分列&#xff0c;弹出“文本分列向导”弹窗 3.选择“下一步”——“下一步”到步骤3&#xff0c;在“列数据类型”中选中日期-YMD格式&#xff0c;点击“完成…

【C++进阶】深入了解继承机制

目录 前言 1. 继承的概念 2. 继承的定义 3. 继承中基类与派生类的赋值转换 4. 继承中的作用域 5. 派生类的默认成员函数 6. 继承与友元、静态成员 7. 多继承与菱形继承 7.1 如何解决 前言 继承是面向对象编程中的一个重要概念&#xff0c;也是面向对象编程语言中普遍存在的特…

主数据管理是数字化转型成功的基石——江淮汽车案例分享

汽车行业数字化转型的背景 在新冠疫情导火索的影响下&#xff0c;经济全球化政治基础逐渐动摇。作为全球最大的汽车市场&#xff0c;我国的汽车市场逐渐由增量转为存量市场。 在数字化改革大背景下&#xff0c;随着工业4.0时代的到来&#xff0c;江淮汽车集团力争实现十四五数…

BFS中的双向广搜和A-star

双向广搜 190. 字串变换 - AcWing题库 import java.util.*;public class Main{static int N 6, n 0;//规则数不超过6个&#xff0c;n表示规则数量static String[] a new String[N];//字串a&#xff0c;用于规则变换static String[] b new String[N];//字串b&#xff0c;用…

2.2 RK3399项目开发实录-使用USB线缆升级固件(物联技术666)

2.1. 前言 本文介绍了如何将主机上的固件&#xff0c;通过USB数据线烧录到 AIO-3399J 开发板的存储器中。升级时&#xff0c;需要根据主机操作系统和固件类型来选择合适的升级方式。 2.2. 准备工具 AIO-3399J 开发板 固件 主机 良好的双公头USB数据线数据线 2.3. 准备固件 …

leetcode 2.合并两个有序链表

1..题目&#xff1a;合并两个有序链表&#xff1b; 2.用例&#xff1a; 3.解题思路&#xff1a; &#xff08;1&#xff09;函数头&#xff1a;参数是两个链表&#xff1b;返回值为 链表指针 ListNode*&#xff1b; &#xff08;2&#xff09;函数体&#xff1a; 1.首先比较…

python学习笔记-内置异常

概述 Python 中的异常&#xff08;Exception&#xff09;是指在程序执行过程中遇到的错误或异常情况。当程序出现异常时&#xff0c;解释器会停止当前代码的执行&#xff0c;并试图找到匹配的异常处理器来处理异常。如果没有找到合适的异常处理器&#xff0c;程序就会终止并打…

PDF文件转换为图片

现在确实有很多线上的工具可以把pdf文件转为图片&#xff0c;比如smallpdf等等&#xff0c;都很好用。但我们有时会碰到一些敏感数据&#xff0c;或者要批量去转&#xff0c;那么需要自己写脚本来实现&#xff0c;以下脚本可以提供这个功能~ def pdf2img(pdf_dir, result_path…

搭建Facebook直播网络对IP有要求吗?

在当今数字化时代&#xff0c;Facebook直播已经成为了一种极具吸引力的社交形式&#xff0c;为个人和企业提供了与观众直接互动的机会&#xff0c;成为推广产品、分享经验、建立品牌形象的重要途径。然而&#xff0c;对于许多人来说&#xff0c;搭建一个稳定、高质量的Facebook…

【Godot4.2】菜单栏生成函数库menuDB

概述 关于Godot的手动菜单栏制作&#xff0c;我已经在之前的文章中有所描述。 但是对于一些场景&#xff0c;手动制作菜单仍然是一个比较低效的做法。所以我将MenuBar以及基于HBoxContainerMenuButton创建菜单栏写成了一个静态函数库。 利用此函数库我们可以用函数形式构造P…

前后端分离vue+php仓库管理系统 n2bm6

1.功能需求 &#xff08;1&#xff09;系统功能包括 &#xff1a;产品入出库登记、确认入出库信息、删除库内信息、借出信息登记、产品分类管理、&#xff0c;报表生成&#xff0c;事件记录&#xff0c;数据检测、数据警告。 &#xff08;2&#xff09;系统管理员功能&#xf…

基于JSP的毕业设计选题系统的设计与实现

基于JSP的毕业设计选题系统的设计与实现 (源代码论文) A. 项目简介 毕业设计选题系统就是能够使学生通过互联网完成毕业设计课题的选定&#xff0c;它采用Web方式&#xff0c;同时适用于局域网和Internet&#xff0c;它要实现审核&#xff0c;权限管理&#xff0c;邮件通知…

C# OpenCvSharp DNN Yolov8-OBB 旋转目标检测

目录 效果 模型信息 项目 代码 下载 C# OpenCvSharp DNN Yolov8-OBB 旋转目标检测 效果 模型信息 Model Properties ------------------------- date&#xff1a;2024-02-26T08:38:44.171849 description&#xff1a;Ultralytics YOLOv8s-obb model trained on runs/DOT…

有适合短视频剪辑软件的吗?分享4款热门软件!

在数字时代&#xff0c;短视频已成为人们获取信息、娱乐消遣的重要形式。随着短视频行业的蓬勃发展&#xff0c;市场上涌现出众多短视频剪辑软件&#xff0c;它们功能各异&#xff0c;各具特色。本文将为您详细介绍几款热门短视频剪辑软件&#xff0c;助您轻松掌握短视频剪辑技…

BIO实战、NIO编程与直接内存、零拷贝深入辨析

BIO实战、NIO编程与直接内存、零拷贝深入辨析 长连接、短连接 长连接 socket连接后不管是否使用都会保持连接状态多用于操作频繁&#xff0c;点对点的通讯&#xff0c;避免频繁socket创建造成资源浪费&#xff0c;比如TCP 短连接 socket连接后发送完数据后就断开早期的http服…

phpldapadmin This base cannot be created with PLA

phpldapadmin This base cannot be created with PLA 1、问题描述2、问题分析3、解决方法&#xff1a;创建根节点 1、问题描述 安装phpldapadmin参考链接: https://blog.csdn.net/OceanWaves1993/article/details/136048686?spm1001.2014.3001.5501 刚安装完成phpldapadmin&…

MyCAT从入门到实战(MyCAT2注释配置)

重置配置 /* mycat:resetConfig{} */; 用户相关 创建用户 /* mycat:createUser{ "username":"user", "password":"", "ip":"127.0.0.1", "transactionType":"xa"} */; 删除用户 /* myc…

软件License授权原理

软件License授权原理 你知道License是如何防止别人破解的吗&#xff1f;本文将介绍License的生成原理&#xff0c;理解了License的授权原理你不但可以防止别人破解你的License&#xff0c;你甚至可以研究别人的License找到它们的漏洞。喜欢本文的朋友建议收藏关注&#xff0c;…

Maya笔记 设置工作目录

Maya会把素材场景等自动保存在工作目录里&#xff0c;我们可以自己定义工作目录 步骤1 创建workspace.mel文件 文件/设置项目 ——>选择一个文件夹&#xff0c;点击设置——>创建默认工作区 这一个后&#xff0c;可以在文件夹里看到.mel文件 步骤2 自动创建文件夹…

华为OD机试真题-靠谱的车-2023年OD统一考试(C卷)---Python3-开源

题目&#xff1a; 考察内容&#xff1a; 思维转化&#xff0c;进制转化&#xff0c;9进制转为10进制&#xff0c;在4的位置1&#xff0c;需要判断是否大于4 代码&#xff1a; """ 题目分析&#xff1a; 9进制转化为10进制23-25 39-50 399-500输入&#xff1a…