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

相关推荐
一路往蓝-Anbo20 小时前
STM32单线串口通讯实战(五):RTOS架构 —— 线程安全与零拷贝设计
c语言·开发语言·stm32·单片机·嵌入式硬件·观察者模式·链表
今天也好累20 小时前
C语言安全格式化:snprintf核心指南
c语言·笔记·学习·visual studio
leiming620 小时前
c++ map容器
开发语言·c++·算法
杨校20 小时前
杨校老师课堂备赛C++信奥之模拟算法习题专项训练
开发语言·c++·算法
世洋Blog20 小时前
AStar算法基础学习总结
算法·面试·c#·astar·寻路
haing201920 小时前
七轴协作机器人运动学正解计算方法
算法·机器学习·机器人
谈笑也风生21 小时前
把二叉搜索树转换为累加树(一)
算法
youngee1121 小时前
hot100-64跳跃游戏
算法·游戏
liu****1 天前
机器学习-线性回归
人工智能·python·算法·机器学习·回归·线性回归
智者知已应修善业1 天前
【数组删除重复数据灵活算法可修改保留重复数量】2024-3-4
c语言·c++·经验分享·笔记·算法