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

server/2024/11/26 15:47:11/

题目:

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];elsedp[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];elsedp[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


http://www.ppmy.cn/server/145102.html

相关文章

Excel求和如何过滤错误值

一、问题的提出 平时&#xff0c;我们在使用Excel时&#xff0c;最常用的功能就是求和了&#xff0c;一说到求和你可能想到用sum函数&#xff0c;但是如果sum的求和区域有#value #Div等错误值怎么办&#xff1f;如下图&#xff0c;记算C列中工资的总和。 直接用肯定会报错&…

路由器中继与桥接

一 . 背景 现在的路由器大多数已经开始支持多种网络连接模式&#xff0c;以下将以TP-Link迷你无线路由器为例进行展开介绍。在TP-Link迷你无线路由器上一般有AP&#xff08;接入点&#xff09;模式&#xff0c;Router&#xff08;无线路由&#xff09;模式&#xff0c;Repeate…

CentOS 7安装SSHFS 实现远程主机目录 挂载为本地目录

安装sshfs 官方下载地址 https://github.com/libfuse/sshfs/releases 首先&#xff0c;我们需要安装sshfs软件。sshfs是一个基于SSH文件传输协议的文件系统客户端&#xff0c;它的官方网页是&#xff1a;http://fuse.sourceforge.net/sshfs.html 。在CentOS下&#xff0c;我们…

网络安全:保护数字世界的堡垒

网络安全&#xff1a;保护数字世界的堡垒 在当今数字化时代&#xff0c;网络安全已成为个人、企业和政府机构必须面对的重要议题。随着互联网的普及和信息技术的发展&#xff0c;网络攻击手段日益复杂多样&#xff0c;从数据泄露、勒索软件到高级持续性威胁&#xff08;APT&am…

Vercel 设置自动部署 GitHub 项目

Vercel 设置自动部署 GitHub 项目 问题背景 最近 Vercel 调整了其部署政策&#xff0c;免费版用户无法继续使用自动部署功能&#xff0c;除非升级到 Pro 计划。但是&#xff0c;我们可以通过配置 Deploy Hooks 来实现同样的自动部署效果。 解决方案 通过设置 Vercel 的 Dep…

js 原生拖拽排序功能 简单实现

拖拽排序功能还是挺常见的, 涉及到的api 还是挺多的,这里笔记记录一下以免忘记找不到了! 老规矩先上效果图 html部分 <div class"list-box"><div draggable"true" class"item">1</div><div draggable"true" cla…

MySQL面试-1

InnoDB中ACID的实现 先说一下原子性是怎么实现的。 事务要么失败&#xff0c;要么成功&#xff0c;不能做一半。聪明的InnoDB&#xff0c;在干活儿之前&#xff0c;先将要做的事情记录到一个叫undo log的日志文件中&#xff0c;如果失败了或者主动rollback&#xff0c;就可以通…

基于YOLOv8深度学习的智慧课堂教师上课行为检测系统研究与实现(PyQt5界面+数据集+训练代码)

随着人工智能技术的迅猛发展&#xff0c;智能课堂行为分析逐渐成为提高教学质量和提升教学效率的关键工具之一。在现代教学环境中&#xff0c;能够实时了解教师的课堂表现和行为&#xff0c;对于促进互动式教学和个性化辅导具有重要意义。传统的课堂行为分析依赖于人工观测&…