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

相关推荐
珹洺1 小时前
C++从入门到实战(十)类和对象(最终部分)static成员,内部类,匿名对象与对象拷贝时的编译器优化详解
java·数据结构·c++·redis·后端·算法·链表
写bug的小屁孩1 小时前
移动零+复写零+快乐数+盛最多水的容器+有效三角形的个数
c++·算法·双指针
飞川撸码1 小时前
【LeetCode 热题100】208:实现 Trie (前缀树)(详细解析)(Go语言版)
算法·leetcode·golang·图搜索算法
这就是编程2 小时前
自回归模型的新浪潮?GPT-4o图像生成技术解析与未来展望
人工智能·算法·机器学习·数据挖掘·回归
羑悻的小杀马特2 小时前
【狂热算法篇】探寻图论幽径:Bellman - Ford 算法的浪漫征程(通俗易懂版)
c++·算法·图论·bellman_ford算法
Fantasydg6 小时前
DAY 31 leetcode 142--链表.环形链表
算法·leetcode·链表
basketball6166 小时前
C++ STL常用算法之常用排序算法
c++·算法·排序算法
qystca6 小时前
蓝桥云客 岛屿个数
算法·dfs·bfs
什码情况7 小时前
回文时间 - 携程机试真题题解
数据结构·python·算法·华为od·机试
lwewan8 小时前
26考研——栈、队列和数组_数组和特殊矩阵(3)
数据结构·笔记·考研·算法