装箱问题

Posted #忘乎所以#

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了装箱问题相关的知识,希望对你有一定的参考价值。

装箱问题

发布时间: 2017年8月15日 23:23   最后更新: 2017年8月15日 23:25   时间限制: 1000ms   内存限制: 128M

有一个箱子容量为V(正整数,0<=V<=20000),同时有n个物品(0<n<=30,每个物品有一个体积(正整数)。

要求n个物品中,任取若干个装入箱内,使箱子的剩余空间为最小。

一个整数,表示箱子容量

一个整数,表示有n个物品

接下来n行,分别表示这n 个物品的各自体积

一个整数,表示箱子剩余空间。

复制
24
6
8
3
12
7
9
7
0
就是一个简单的dp.
 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 int k[31];
 4 int dp[20005];
 5 int main(){
 6   int n,m;
 7   scanf("%d%d",&n,&m);
 8   for(int i=1;i<=m;i++){
 9     scanf("%d",&k[i]);
10     for(int j=n;k[i]<=j;j--)
11       dp[j]=max(dp[j],dp[j-k[i]]+k[i]);
12   }
13   printf("%d\n",n-dp[n]);
14   return 0;
15 }

以上是关于装箱问题的主要内容,如果未能解决你的问题,请参考以下文章

在代码中查找装箱的工具

MATLAB实战系列-二维装箱问题之BL法修正版(附MATLAB代码)

关于近似装箱问题的思考。

三维装箱基于matlab求解三维装箱优化问题含Matlab源码 1194期

java拆箱和装箱

都说不要装箱,那装箱到底带来了什么开销?