洛谷 P1049 [NOIP2001 普及组] 装箱问题 C语言 记忆化搜索->‘倒序‘dp->‘正序‘dp

题目:

P1049 NOIP2001 普及组 装箱问题 - 洛谷 | 计算机科学教育新生态

没有什么正序dp和倒序dp,本质就是状态定义和关系转移的不同。我这样是为了好观察

记忆化搜索,代码如下

复制代码
#include <iostream>
using namespace std;
int V,n;
int mem[1005][20005];
int v[35];
int dfs(int x,int SP)
{
    int sum = 0;
    if(mem[x][SP])
        return mem[x][SP];
    if(x > n)
        return 0;
    else if(SP < v[x])
    {
        sum = dfs(x+1,SP);
    }
    else {
        sum = max(dfs(x+1,SP),dfs(x+1,SP-v[x])+v[x]);
    }
    mem[x][SP]= sum;
    return sum;
}
int main(void) {
    cin >> V >> n;

    for(int i = 1 ; i <= n ; i++)
        cin >> v[i];

    int ans = dfs(1,V);
    cout << V - ans;
    return 0;
}

'倒序'dp,代码如下

复制代码
#include <iostream>
using namespace std;
int V,n;
int dp[1005][20005];
int v[35];
int main(int argc, char** argv) {
    cin >> V >> n;

    for(int i = 1 ; i <= n ; i++)
        cin >> v[i];
    for(int i = n ; i >= 1 ; i--)
    {
        for(int SP = 0 ; SP <= V; SP++)
        {
            if(SP < v[i])
                dp[i][SP] = dp[i+1][SP];
            else
                dp[i][SP] = max(dp[i+1][SP],dp[i+1][SP-v[i]]+v[i]);
        }
    }
    int ans = dp[1][V];
    cout << V - ans;
    return 0;
}

'正序'dp代码如下

复制代码
#include <iostream>
using namespace std;
int V,n;
int mem[1005][20005];
int dp[1005][20005];
int v[35];

int main(int argc, char** argv) {
    cin >> V >> n;

    for(int i = 1 ; i <= n ; i++)
        cin >> v[i];

    for(int i = 1 ; i <= n ; i++)
    {
        for(int SP = 0 ; SP <= V; SP++)
        {
            if(SP < v[i])
                dp[i][SP] = dp[i-1][SP];
            else
                dp[i][SP] = max(dp[i-1][SP],dp[i-1][SP-v[i]]+v[i]);
        }
    }
    int ans = dp[n][V];
    cout << V - ans;
    return 0;
}

三个代码都是AC

相关推荐
東隅已逝,桑榆非晚15 分钟前
新手入门指南:认识 C 语言文件操作(上)
c语言·开发语言·笔记
BD4SXV22 分钟前
线性二次调节器(Linear Quadratic Regulator,LQR)的无限时域最优控制求解与黎卡提方程
算法·自动化
ST——Jess30 分钟前
2026年度传统文化数字化与命理科技(Ethno-tech)行业趋势研究报告:专业级数智工作台的技术壁垒与评测标准
人工智能·科技·算法·架构
Matrix_111 小时前
第13篇:非线性位移场——漩涡、鱼眼、水波纹与球面化
图像处理·算法
Lucky_ldy1 小时前
数据结构从入门到精通:顺序表
数据结构·链表
金牌归来发现妻女流落街头1 小时前
【LeetCode 第207题】
算法·leetcode·拓扑·领接表
社交怪人1 小时前
【A×B】信息学奥赛一本通C语言解法(题号1036)
c语言
熬夜敲代码的猫1 小时前
AVL树(C++详解版)
数据结构·c++·算法
-To be number.wan1 小时前
算法日记 | STL-MAP
c++·算法
cjp5601 小时前
015. UG 二次开发,拉伸草图生成实体类,高级草图类封装
算法