【动态规划】01背包问题-练习题-采药
题目描述
辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师。为此,他想拜附近最有威望的医师为师。医师为了判断他的资质,给他出了一个难题。医师把他带到一个到处都是草药的山洞里对他说:“孩子,这个山洞里有一些不同的草药,采每一株都需要一些时间,每一株也有它自身的价值。我会给你一段时间,在这段时间里,你可以采到一些草药。如果你是一个聪明的孩子,你应该可以让采到的草药的总价值最大。”
如果你是辰辰,你能完成这个任务吗?
输入格式
第一行有 22 个整数 TT(1 \le T \le 10001≤T≤1000)和 MM(1 \le M \le 1001≤M≤100),用一个空格隔开,TT 代表总共能够用来采药的时间,MM 代表山洞里的草药的数目。
接下来的 MM 行每行包括两个在 11 到 100100 之间(包括 11 和 100100)的整数,分别表示采摘某株草药的时间和这株草药的价值。
输出格式
输出在规定的时间内可以采到的草药的最大总价值。
输入输出样例
输入 #1 复制
70 3
71 100
69 1
1 2
输出
3
题解代码
跟上一个问题一致都是简单的01背包问题
#include<iostream>
using namespace std;int t,m;
int ti[10001],v[10001];
int f[10001][10001];
//01背包
int main(){cin>>t>>m;for(int i=1;i<=m;i++)cin>>ti[i]>>v[i]; for(int i=1;i<=m;i++)for(int j=1;j<=t;j++){if(j>=ti[i])f[i][j]=max(f[i-1][j],f[i-1][j-ti[i]]+v[i]);else f[i][j]=f[i-1][j];}/*一维的int t[101] ,f[1001];for(int i=1;i<=m;i++)for(j=t;j>=t[i];j--) f[j]=max(f[j],f[j-ti[i]]+p[i]);*/cout<<f[m][t];return 0;
}
【动态规划】01背包问题-练习题-采药相关推荐
- 【动态规划】P1048 01背包问题:采药
时间对应容量,用01背包 [动态规划笔记]01背包问题及优化_m0_52043808的博客-CSDN博客 代码: #include<iostream> using namespace st ...
- 动态规划—01背包问题
原文作者:弗兰克的猫 原文地址:[动态规划]01背包问题 摘要: 01背包问题:n个物品放入容量为c的背包中. 常见解法: 分治法:递归计算,且存在重复计算的bug 自上而下填表法:从大到小使用递归计 ...
- 动态规划——0-1背包问题
文章出处:极客时间<数据结构和算法之美>-作者:王争.该系列文章是本人的学习笔记. 1 0-1背包问题 背包能够承受的总重量一定w,每个物品的总量不同int[] weight表示.怎么放才 ...
- 动态规划——01背包问题 看此一篇文章就够了
本文讲述经典算法--动态规划的 常见问题 01背包 一篇文章带你学会01背包问题,妈妈再也不担心我遇到01背包了!!! 问题描述 有n个物品,它们有各自的体积和价值,现有给定容量m的背包,如何让背包 ...
- 动态规划---01背包问题(2种方法)
一.动态规划 代表一类问题(最优子结构或子问题最优性)的一般解法,是设计方法或者策略,不是具体算法 本质:递推,核心是找到状态转移的方式,写出dp方程. 解决问题:交叉,重叠子问题(最优子问题) 形式 ...
- 动态规划01背包问题入门学习,详细笔记,推荐阅读
问题描述: 给定N种物品和一个背包.物品i的重量是Wi,其价值位Vi ,背包的容量为C.问应该如何选择装入背包的物品,使得转入背包的物品的总价值为最大?? 在选择物品的时候,对每种物品i只有两种选择, ...
- python实现动态规划0-1背包问题
一.动态规划算法介绍 动态规划算法通常用于求解具有某种最优性质的问题.在这类问题中,可能会有许多可行解.每一个解都对应于一个值,我们希望找到具有最优值的解.动态规划算法与分治法类似,其基本思想也是将待 ...
- 详解动态规划01背包问题--JavaScript实现
对其他动态规划问题感兴趣的,也可以查看 详解动态规划最少硬币找零问题--JavaScript实现 详解动态规划最长公共子序列--JavaScript实现 一开始在接触动态规划的时候,可能会云里雾里,似 ...
- 动态规划--01背包问题详解
代码随想录day42和day43 动态规划 模块01背包问题 "即使到不了远方,心中也要有远方的模样." 文章目录 1. 01背包理论基础 1.1什么是背包问题 1.2二维dp数组 ...
最新文章
- python面试题及答案-Python 45道基本面试题及答案 (新手非常有用)
- 记录一次Mac虚拟机安装的过程(有图有真相)
- Webstorm PhpStorm的序列号和证书
- Filter若不写chain.doFilter(request,response)原Servlet路径代码不会被执行
- 为何那么多移动互联网APP慢慢失败
- Industry AI Live | 行为动作定位的算法流程介绍与分享
- 超全!Python获取某一日期是“星期几”的6种方法!
- ogg 故障解决一则
- datagrip中运行sql语句
- 深入学习SAP UI5框架代码系列之四:SAP UI5控件的元数据实现
- 【渝粤教育】国家开放大学2018年春季 0273-21T中国现代文学 参考试题
- mysql数据加百分号_使用MySQL SELECT语句时,在每个值的末尾添加一个百分号(%)...
- 微擎在线goto解密系统
- 搭建GoldenGate的单向复制环境(转)
- TextView跑马灯效果
- Android开发(十八)——头部、中部、底部布局技巧
- 小组学习电子教室等同屏工具调研
- python主函数怎么写_python怎么写函数
- ITM Architecture/ ITM 架构
- 【DG】DG日常维护