动态规划解决背包问题

目录

动态规划步骤:

1.01背包问题

2.完全背包问题


动态规划步骤:

 step1.分析问题,定义dp数组(下标含义)

step2.初始化dp数组(边界)

step3.写dp状态转换方程(明确dp数组遍历顺序)

1.01背包问题

        即物品均只能取1次

46. 携带研究材料(第六期模拟笔试) (kamacoder.com)icon-default.png?t=N7T8https://kamacoder.com/problempage.php?pid=1046

#include <iostream>
#include <vector>
using namespace std;void debug_input(vector<int>& vec){for(auto it=vec.begin(); it!=vec.end(); it++){cout<<*it<<" ";}cout<<endl;
}class solution
{
public:int max_value(vector<int>& space, vector<int>& value, int M, int N){// 定义dp[i][j]vector<vector<int>> dp(M+1, vector<int> (N+1, 0));//初始化for(int j=space[0]; j<=N; j++)dp[0][j] = value[0];//状态转换for(int i=1; i<M; i++){for(int j=1; j<=N; j++){if(j < space[i]) dp[i][j] = dp[i-1][j];else dp[i][j] = max( dp[i-1][j], dp[i-1][j-space[i]] + value[i]); }}return dp[M-1][N];}
};int main(){// inputint M,N,input;cin>>M>>N;vector<int> space(M,0);vector<int> value(M,0);for(int i=0; i<M; i++){cin>>input;space[i] = input;}for(int i=0; i<M; i++){cin>>input;value[i] = input;}// // debug input// debug_input(space);// debug_input(value);//solvesolution mysolve;cout<<mysolve.max_value(space, value, M, N);return 0;
}

2.完全背包问题

        即满足条件下,每个物品可取无数次。 

52. 携带研究材料(第七期模拟笔试) (kamacoder.com)icon-default.png?t=N7T8https://kamacoder.com/problempage.php?pid=1052 

#include <iostream>
#include <vector>
using namespace std;void debug_input(vector<int>& vec){for(auto it=vec.begin(); it!=vec.end(); it++){cout<<*it<<" ";}cout<<endl;
}class solution
{
public:int max_value(vector<int>& space, vector<int>& value, int total_num, int total_space){// 定义dp[i][j]vector<vector<int>> dp(total_num, vector<int> (total_space+1, 0));//初始化for(int j=space[0]; j<=total_space; j++){dp[0][j] = dp[0][j-space[0]] + value[0];}//状态转换for(int i=1; i<total_num; i++){for(int j=1; j<=total_space; j++){if(j < space[i]) dp[i][j] = dp[i-1][j];else dp[i][j] = max( dp[i-1][j], dp[i][j-space[i]]+value[i]);}}return dp[total_num-1][total_space];}
};int main(){//inputint total_num, total_space;cin>>total_num>>total_space;vector<int> space(total_num,0);vector<int> value(total_num,0);int s, v;for(int i=0; i<total_num; i++){cin>>s>>v;space[i] = s;value[i] = v;}// debug_input(space);// debug_input(value);//solvesolution mysolve;cout<<mysolve.max_value(space, value, total_num, total_space);return 0;
}

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

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

相关文章

【Web】CTFSHOW-ThinkPHP5-6反序列化刷题记录(全)

目录 web611 web612 web613-622 web623 web624-626 纯记录exp&#xff0c;链子不作赘述 web611 具体分析&#xff1a; ThinkPHP-Vuln/ThinkPHP5/ThinkPHP5.1.X反序列化利用链.md at master Mochazz/ThinkPHP-Vuln GitHub 题目直接给了反序列化入口 exp: <?ph…

【刷题】图论——最小生成树:局域网

要想去除边&#xff0c;并且不改变连通性&#xff0c;而且去除的值最大&#xff0c;相当于保留最小生成树。 注意这题连通块有若干个&#xff0c;所以运行Kruskal相当于形成若干个最小生成树。 如果是prim只能事先处理好各个连通块&#xff0c;然后在连通块内部单独用prim 题目…

算法稳定币是未来趋势?

加密货币市场最近如火如荼的行情&#xff0c;稳定币作为不可或缺的一环可谓表现突出&#xff0c;目前总市值已超过 210 亿美元。新晋算法稳定币自带天然吸睛的博弈、投机、套利等行为&#xff0c;铺就了一个个极具吸引力的财富故事&#xff0c;进一步把加密世界的货币试验推到新…

动态规划(Dynamic Programming)详解

引言&#xff1a; 动态规划&#xff08;Dynamic Programming&#xff0c;简称DP&#xff09;是计算机科学与数学领域中的一个经典算法设计策略&#xff0c;用于解决具有重叠子问题和最优子结构特性的复杂问题。它通过将问题分解为更小的子问题来避免重复计算&#xff0c;从而提…

【vue】watch 侦听器

watch&#xff1a;可监听值的变化&#xff0c;旧值和新值 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><titl…

HarmonyOS开发实例:【自定义Emitter】

介绍 本示例使用[Emitter]实现事件的订阅和发布&#xff0c;使用[自定义弹窗]设置广告信息。 效果预览 使用说明 进入首页后弹出广告弹窗&#xff0c;点击即可关闭。点击商品列表中的一个商品可以跳转到商品详情页。在商品详情页点击首页可以返回到商品列表页&#xff0c;点…

结构型模式--2.桥接模式【大海贼时代】

1. 组建海贼团 哥尔D罗杰是罗杰海贼团船长。他最终征服了伟大航路&#xff0c;完成了伟大航路的航行&#xff0c;被人们成为海贼王。后来得了绝症&#xff0c;得知自己命不久矣&#xff0c;主动自首并在东海罗格镇被处刑。临死前罗杰的一句话“想要我的宝藏吗&#xff1f;想要…

std命名空间是C++标准库的命名空间

已经导入#include <string>&#xff0c;为何还要用 std::string&#xff1f;&#xff1f; 导入<string>头文件只是告诉编译器你要使用标准库中与字符串相关的功能&#xff0c;比如std::string类。然而&#xff0c;C中的标准库使用了命名空间&#xff08;namespace…

电商新宠:淘宝拍立淘API接口助力精准搜索商品信息

淘宝拍立淘API接口&#xff0c;作为电商领域的新宠&#xff0c;正以其独特的图像识别技术为精准搜索商品信息提供强大的助力。这项基于深度学习和计算机视觉技术的先进服务&#xff0c;使得用户能够通过上传图片来快速搜索淘宝平台上的相关商品&#xff0c;极大地提升了购物体验…

弹性云服务器性能对比(内附测试数据),快快网络服务器崭露头角

随着计算技术的不断革新&#xff0c;云服务器已成为企业和个人部署应用与服务的首选。尤其线上业务日益盛行的今天&#xff0c;云服务商的实力更是备受瞩目。对于企业而言&#xff0c;高稳定&#xff0c;存储速度都是不可或缺的基本要求&#xff0c;这些都对公有云的云端编解码…

【Linux系统】进程状态

1.直接谈论Linux的进程状态 Linux进程状态本质上是task_struct这个结构体内的一个变量用来存储进程状态。 task_struct { //内部的一个属性 int status; } R运行状态&#xff08;running&#xff09;: 并不意味着进程一定在运行中&#xff0c;它表明进程要么是在运行中要么在运…

【hive】mysql数据库作为metastore,hive hiveserver2启动报错All is already granted by admin

报错内容&#xff1a; All is already granted by admin role admin already exists在mysql数据库设置&#xff0c;即可解决&#xff1a; SET GLOBAL binlog_format ROW; COMMIT;转自&#xff1a;Part1-3&#xff1a;开发环境搭建(3)----Hive

ubuntu 安装多版本 python 并使用

需求&#xff1a; ubuntu 20.04 默认python 是3.8&#xff0c; 但是有些代码是老的&#xff0c;无法使用3.8编译 进程&#xff1a; 默认源没有 python 3.7 的版本需要加一个源apt install software-properties-common -y && add-apt-repository -y ppa:deadsnakes/p…

【深度学习】深度学习md笔记总结第4篇:TensorFlow介绍,学习目标【附代码文档】

深度学习笔记完整教程&#xff08;附代码资料&#xff09;主要内容讲述&#xff1a;深度学习课程&#xff0c;深度学习介绍要求,目标,学习目标,1.1.1 区别,学习目标,学习目标。TensorFlow介绍&#xff0c;2.4 张量学习目标,2.4.1 张量(Tensor),2.4.2 创建张量的指令,2.4.3 张量…

hbase基础shell用法

HBase中用create命令创建表&#xff0c;具体如下&#xff1a; create student,Sname,Ssex,Sage,Sdept,course 此时&#xff0c;即创建了一个“student”表&#xff0c;属性有&#xff1a;Sname,Ssex,Sage,Sdept,course。因为HBase的表中会有一个系统默认的属性作为行键&#x…

ubuntu添加环境变量

在Ubuntu中&#xff0c;添加环境变量有多种方法&#xff0c;下面列出三种常见的方法&#xff1a; 方法一&#xff1a;临时设置 使用export命令直接修改PATH的值&#xff0c;例如&#xff0c;如果想在$PATH中增加JAVA文件夹&#xff0c;可以执行以下命令&#xff1a; export …

李彦宏放话:百度AI大模型绝不抢开发者饭碗

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 昨晚&#xff0c;李彦宏内部讲话称&#xff1a;AI大模型开源意义不大&#xff0c;百度绝不抢开发者饭碗。 但你一定要说话算话哦&#xff0c;可千万别说&#xff1a;“我永远不做手机&#xff0c;谁再敢提做手机就给…

科技云报道:从“奇点”到“大爆炸”,生成式AI开启“十年周期”

科技云报道原创。 世界是复杂的&#xff0c;没有人知道未来会怎样&#xff0c;但如果单纯从技术的角度&#xff0c;我们总是能够沿着技术发展的路径&#xff0c;找到一些主导未来趋势的脉络。 从Sora到Suno&#xff0c;从OpenAI到Copilot、Blackwell&#xff0c;这些热词在大…

大批量插入数据到MySQL六种策略

大批量插入数据到MySQL时&#xff0c;为了提高效率并减少对数据库的负担&#xff0c;可以采用以下六种策略&#xff1a; 1. 批量插入&#xff08;Batch Insert&#xff09; 使用单个 INSERT INTO 语句插入多行数据&#xff0c;而不是为每一行数据单独执行一次 INSERT。这样可以…

[温故] 红黑树算法

前言 最近在突然想起一些基础的东西, 向着温故知新, 有了些新的感悟和大家分享一下. 排序算法是数据结构的一个重要组成部分, 当时学习的时候没有少折腾, 这里来看看大佬们怎么运用这些数据结构来构建庞大的计算机体系的. 二叉树是排序算法的一个衍生, 基于二叉树的构建不同…