第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

CSP-J 2019紀(jì)念品題解(洛谷P5662):動(dòng)態(tài)規(guī)劃+完全背包問(wèn)題的實(shí)戰(zhàn)應(yīng)用

標(biāo)簽:
C++

https://img1.sycdn.imooc.com/f8857d680879fd4f09380693.jpg

一、题目解读

2019年CSP-J的“纪念品”问题(对应洛谷P5662)要求玩家在T天内通过买卖纪念品最大化金币收益。每天可交易N种商品,需计算最优策略下的最终金币数。题目强调动态规划思维与资源分配优化,是算法竞赛中的经典题型。

二、解题思路

核心思路为“动态规划+完全背包问题”。每天将当前商品价格与次日差价视为“物品价值”,通过滚动计算次日可获得的“最大收益背包”,动态更新总金币数。关键在于将“连续两天的差价利润”转化为可重复选择的“背包物品”,利用dp[i](i金币时的最大收益)实现状态转移

三、解题步骤

1. 输入处理:读取天数T、商品数N、初始金币M及每日价格矩阵

2. 外层循环遍历T-1天(最后一天无法交易)。

3. 内层循环处理当日商品:计算差价profit,仅对正利润商品执行完全背包更新(避免无利操作)。

4. 状态转移方程:dp[j]=max(dp[j],dp[j-cost]+profit),实现“用剩余金币重复购买差价商品”的逻辑。

5. 每日结束后,将dp[M]累加到总金币M,滚动优化。

四、代码与注释

#include <iostream>#include <vector>#include <algorithm>using namespace std;int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr); // 优化输入效率
    
    int T, N, M;
    cin >> T >> N >> M; // 输入天数、商品数、初始金币
    
    vector<vector<int>> prices(T, vector<int>(N)); // 价格矩阵
    for (int i = 0; i < T; ++i) {
        for (int j = 0; j < N; ++j) {
            cin >> prices[i][j];
        }
    }
    
    // 每天处理时,计算当天到第二天的最大收益
    for (int day = 0; day < T - 1; ++day) {
        vector<int> dp(M + 1, 0); // dp[i]表示i金币能获得的最大收益
        
        for (int item = 0; item < N; ++item) {
            int cost = prices[day][item];
            int profit = prices[day + 1][item] - cost; // 次日差价
            
            if (profit <= 0) continue; // 无利可图则跳过
            
            // 完全背包问题解法
            for (int j = cost; j <= M; ++j) { // 从成本开始累加
                dp[j] = max(dp[j], dp[j - cost] + profit); // 状态转移
            }
        }
        
        // 更新最大金币数
        M += dp[M];
    }
    
    cout << M << endl; // 输出最终金币
    return 0;}

五、总结

该解法巧妙将“连续两天的利润”抽象为可重复选择的“背包物品”,通过动态规划规避了复杂的路径搜索。关键在于识别问题中的“资源可重复利用”特性,并应用完全背包模型简化计算。对算法竞赛中的资源分配类问题具有重要参考价值。

来源:CSP题解


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫(xiě)下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專(zhuān)欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消