洛谷 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

相关推荐
水饺编程5 分钟前
第4章,[标签 Win32] :文本的格式化,等待完善
c语言·c++·windows·visual studio
季明洵18 分钟前
反转字符串、反转字符串II、反转字符串中的单词
java·数据结构·算法·leetcode·字符串
2401_8414956423 分钟前
【Python高级编程】近似串匹配
python·算法·动态规划·字符串·数组·时间复杂度·空间复杂度
lingggggaaaa27 分钟前
安全工具篇&魔改二开&CheckSum8算法&Beacon密钥&Stager流量&生成机制
学习·算法·安全·web安全·网络安全·免杀对抗
Python+JAVA+大数据29 分钟前
SQL玩出算法竞赛高度!郑凌云数独算法:递归CTE+位运算DFS回溯全解析
数据库·sql·算法·搜索引擎·深度优先·dfs
Hello World . .30 分钟前
数据结构:哈希表(Hash table)
数据结构·vim·哈希算法·散列表
MicroTech202532 分钟前
量子主成分分析(QPCA):微算法科技(NASDAQ :MLGO)重构图像降维与特征提取的技术
科技·算法·重构
历程里程碑34 分钟前
滑动窗口------滑动窗口最大值
大数据·python·算法·elasticsearch·搜索引擎·flask·tornado
Mr_Xuhhh34 分钟前
C语言字符串与内存操作函数模拟实现详解
java·linux·算法
B站_计算机毕业设计之家37 分钟前
AI大模型:Deepseek美食推荐系统 机器学习 协同过滤推荐算法+可视化 Django框架 大数据毕业设计(源码)✅
python·算法·机器学习·数据分析·django·推荐算法·美食