博客
关于我
ALGO-30 算法训练 入学考试
阅读量:729 次
发布时间:2019-03-21

本文共 812 字,大约阅读时间需要 2 分钟。

为了解决这个问题,我们需要使用动态规划来解决一个典型的0-1背包问题。我们需要在给定的时间内选择草药,使其总价值最大化。

方法思路

  • 问题分析:这个问题类似于0-1背包问题,其中每个物品只能被选择一次,且不能超过总时间限制。
  • 动态规划状态定义:我们定义dp[j]表示在时间j内能够获得的最大价值。
  • 状态转移方程
    • 如果当前草药的采集时间超过剩余时间,直接舍弃该草药。
    • 如果当前草药的采集时间在剩余时间内,选择采集或不采集,取最大值。
  • 优化考虑:使用一维数组来优化空间复杂度,通过逆序遍历时间进行处理。
  • 解决代码

    #include 
    using namespace std;int main() { int T, M; // 读取输入 cin >> T >> M; // 一维数组初始化 int dp[T + 1] = {0}; for (int i = 0; i < M; ++i) { int a, b; cin >> a >> b; for (int j = T; j >= a; --j) { dp[j] = max(dp[j], dp[j - a] + b); } } cout << dp[T] << endl; return 0;}

    代码解释

    • 输入读取:读取总时间T和草药数量M,然后逐行读取每株草药的采集时间和价值。
    • 动态规划数组初始化:使用一维数组dp,初始化为0,表示不选择任何草药时的价值。
    • 处理每株草药:对每株草药,逆序遍历时间,更新可能的最大价值。对于每个时间j,如果草药的采集时间小于等于j,则更新dp[j]为最大价值。
    • 输出结果:最终输出在总时间内的最大价值。

    这种方法确保了我们在给定的时间内选择了最优的草药组合,实现了动态规划的时间和空间优化。

    转载地址:http://grdgz.baihongyu.com/

    你可能感兴趣的文章
    mysql字段类型不一致导致的索引失效
    查看>>
    mysql字段类型介绍
    查看>>
    mysql字段解析逗号分割_MySQL逗号分割字段的行列转换技巧
    查看>>
    MySQL字符集与排序规则
    查看>>
    MySQL字符集乱码
    查看>>
    mysql字符集设置
    查看>>
    mysql存储IP地址的数据类型
    查看>>
    mysql存储中文 但是读取乱码_mysql存储中文乱码
    查看>>
    MySQL存储引擎
    查看>>
    MySQL存储引擎--MYSIAM和INNODB引擎区别
    查看>>
    Mysql存储引擎(2):存储引擎特点
    查看>>
    MySQL存储引擎--MyISAM与InnoDB区别
    查看>>
    mysql存储总结
    查看>>
    mysql存储登录_php调用mysql存储过程会员登录验证实例分析
    查看>>
    MySql存储过程中limit传参
    查看>>
    MySQL存储过程入门
    查看>>
    mysql存储过程批量建表
    查看>>
    MySQL存储过程的使用实现数据快速插入
    查看>>
    mysql存储过程详解
    查看>>
    Mysql存表情符号发生错误
    查看>>