当前位置:首页 > 洛谷 > 洛谷P1616题解:动态规划之完全背包问题

洛谷P1616题解:动态规划之完全背包问题

8个月前 (07-14)

洛谷P1616题解:动态规划之完全背包问题 洛谷题解 动态规划 完全背包问题 C++ 第1张

一、题目解读

洛谷P1616题要求在一个包含M个活动(每个活动有固定时间和价值)的场景中,求解在总时间T内选择活动的最优组合,使得总价值最大化。活动可重复选择,需利用动态规划算法找到最优解。题目强调时间限制与价值收益的平衡,属于典型的完全背包问题变体。

二、解题思路

1. 动态规划核心思想:将问题拆解为子问题,通过状态转移方程逐步求解全局最优解。

2. 完全背包模型:与01背包不同,完全背包允许每个物品(活动)被选择多次,因此状态转移需考虑重复选择的可能性。

3. 优化策略:使用一维DP数组(空间优化),通过正序遍历容量(时间)实现状态更新,避免重复计算。

三、解题步骤

1. 数据输入与初始化:

○ 读取总时间T和活动数量M。

○ 使用vector存储每个活动的时间time和价值value。

○ 初始化DP数组dp,其中dp[j]表示在时间j内可获得的最高价值。

2. 动态规划循环:

○ 外层遍历活动(物品),内层正序遍历时间(容量)。

○ 状态转移方程:dp[j] = max(dp[j], dp[j - time[i]] + value[i]),即当前时间j的价值可选择“不选该活动”或“选该活动并扣除其时间后剩余价值+当前价值”。

3. 输出结果:dp数组的最后一个元素dp[t]即为最优解。

四、代码与注释

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main() {
    int t, m;  // t为总时间,m为活动数量
    cin >> t >> m;
    
    vector<int> time(m), value(m);  // time存储活动时间,value存储活动价值
    for (int i = 0; i < m; ++i) {
        cin >> time[i] >> value[i];
    }
    
    vector<long long> dp(t + 1, 0);  // dp[i]表示前i时间内的最大价值,初始化为0
    
    // 完全背包核心算法
    for (int i = 0; i < m; ++i) {  // 遍历每个活动
        for (int j = time[i]; j <= t; ++j) {  // 正序遍历时间(容量)
            dp[j] = max(dp[j], dp[j - time[i]] + value[i]);  // 状态转移:选择当前活动或不选择
        }
    }
    
    cout << dp[t] << endl;  // 输出最终结果
    return 0;
}

五、总结

本文通过动态规划方法解决了洛谷P1616题中的时间价值优化问题,利用完全背包模型允许重复选择的特点,通过简洁的状态转移方程实现了高效求解。代码采用一维DP数组降低空间复杂度,正序遍历确保重复选择的有效性。该解法为同类背包问题提供了通用框架,需重点理解状态定义与转移逻辑,适用于资源可重复利用的最优决策场景。


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

题目解读给定一个整数数组,我们需要找到一个中心索引,使得该索引左侧所有元素的和等于右侧所有元素的和。如果不存在这样的索引,则返回-1。中心索引的定义不包含在左右两侧的和计算中。这个问题考察对数组遍历和...

NOIP2005 普及组 洛谷P1408 背包问题的空间优化技巧与实战应用

NOIP2005 普及组 洛谷P1408 背包问题的空间优化技巧与实战应用

题目重解想象你是一名药师,有t分钟在山上采集m种草药。每种草药需要time分钟采集,价值为num。这就像考试时分配时间做题,要选择收益最大的题目组合。题目要求计算在规定时间内能获得的最大草药价值。解题...

IOI 1994 洛谷1216:如何用动态规划高效解决数字三角形问题?附完整代码解析

IOI 1994 洛谷1216:如何用动态规划高效解决数字三角形问题?附完整代码解析

题目重解给定一个由数字组成的三角形结构,从顶部出发,每次可以移动到下方相邻的数字,最终到达底部。我们的目标是找到一条路径,使得路径上经过的数字总和最大。这个问题在实际中有许多应用场景,如最优路径规划、...

力扣965题深度解析:单值二叉树的判断技巧

力扣965题深度解析:单值二叉树的判断技巧

重新解读题目 判断一棵二叉树是否为“单值二叉树”,即所有节点的值是否完全相同。题目看似简单,实则考验对树结构递归特性的理解。若一棵树的所有节点值相同,其必然满足:根节点与左右子树的值一致,且...

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

GESP2023年六级真题解析:动态规划解决小杨买饮料问题(洛谷3873)

一、题目解读小杨买饮料是GESP 2023年六级认证考试中的一道经典动态规划题目,考察学生对背包问题的理解和应用能力。题目描述小杨需要购买n种饮料,每种饮料有特定的体积w和价格v,他要在不超过容量l的...

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

一、题目解读题目要求在一个n×m的网格中,从左上角到右下角选择一条路径,路径上的数字可重复取用,求取数之和的最大值。路径限制为仅能向右或向下移动。需注意路径的灵活性与重复取数的可能性,传统单向动态规划...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。