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

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

2天前

洛谷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数组降低空间复杂度,正序遍历确保重复选择的有效性。该解法为同类背包问题提供了通用框架,需重点理解状态定义与转移逻辑,适用于资源可重复利用的最优决策场景。


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣198.打家劫舍|动态规划解法中的特殊边界处理

力扣198.打家劫舍|动态规划解法中的特殊边界处理

题意解析:在排列成直线的房屋群中,每个房屋藏有价值不同的财物。小偷不能连续抢劫相邻的两间房屋,否则会触发警报。我们需要设计一套抢劫策略,使得在不触发警报的前提下,能够获取的最大财物总和。这个问题本质上...

力扣1137题:动态规划解泰波那契数 高效求解第N项的秘密

力扣1137题:动态规划解泰波那契数 高效求解第N项的秘密

一:重新解读题目泰波那契数列是一个充满数学趣味的递推序列:从第3项开始,每个数均为前三个数的和(即Tₙ₊₃ = Tₙ + Tₙ₊₁ + Tₙ₊₂)。当给定整数n时,需要高效计算出第n项的值。面对此类递...

力扣144:递归之美 轻松掌握二叉树前序遍历

力扣144:递归之美 轻松掌握二叉树前序遍历

题目解读二叉树的前序遍历是一种基础但重要的树遍历方式,其遍历顺序为:先访问根节点,然后递归地前序遍历左子树,最后递归地前序遍历右子树。给定一个二叉树的根节点,我们需要按照这个顺序访问所有节点,并将它们...

从零到一掌握背包问题:洛谷P1164题解精讲,附带优化

从零到一掌握背包问题:洛谷P1164题解精讲,附带优化

题目重解:小A带着m元钱来到餐馆,菜单上有n道菜,每道菜都有确定的价格。现在需要计算出刚好花完m元的点菜方案总数。这个问题看似简单,但当菜品数量增多时,暴力枚举就会变得不可行,需要更高效的算法来解决。...

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

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

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

牛客12576题解题全解析:动态规划+质因数分解实现跳跃问题最优解

牛客12576题解题全解析:动态规划+质因数分解实现跳跃问题最优解

一、题目解读牛客12576题是一道经典的算法题,要求给定起点N和终点M,求解从N到M的最少跳跃次数。题目考察的核心在于路径优化与动态规划思想,需结合数论中的质因数分解技巧,通过合理设计算法降低时间复杂...

发表评论

访客

看不清,换一张

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