装箱问题

装箱问题是背包问题的变形,其中相对背包问题要简单一点。

一:装箱剩余问题

问题描述

  有一个箱子容量为V(正整数,0<=V<=20000),同时有n个物品(0<n<=30),每个物品有一个体积(正整数)。
  要求n个物品中,任取若干个装入箱内,使箱子的剩余空间为最小。

输入格式

  第一行为一个整数,表示箱子容量;
  第二行为一个整数,表示有n个物品;
  接下来n行,每行一个整数表示这n个物品的各自体积。

输出格式

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

样例输入

24
6
8
3
12
7
9
7

样例输出 0

这题读完之后多思考思考, 其实就能发现就是0-1背包问题

每个物品的体积就是花费同时也是价值,

也就是说这题可以转化为在总体积为w下,可以得到最大的价值

最后用总体积减去最大的价值就是剩下最少的空间

状态转移方程d[j] = max(d[j], d[j - a[i]] + a[i]);

#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
int n;
int d[20005];
int a[35];
int main(){
    int w;
    scanf("%d%d", &w, &n);
    int i, j;
    for (i = 0; i < n; i++){
        scanf("%d", &a[i]);

    }
    memset(d, 0, sizeof(d));

    for (i = 0; i < n; i++){
        for (j = w; j >= a[i]; j--)

            d[j] = max(d[j], d[j - a[i]] + a[i]);

    }
    printf("%d\n", w - d[w]);
    return 0;

}

 

二:多个箱子问题:贪心算法

问题描述:装箱问题可简述如下:设有编号为0、1、…、n-1的n种物品,体积分别为v0、v1、…、vn-1。将这n种物品装到容量都为V的若干箱子里。约定这n种物品的体积均不超过V,即对于0≤i<n,有0<vi≤V。不同的装箱方案所需要的箱子数目可能不同。装箱问题要求使装尽这n种物品的箱子数要少。
   若考察将n种物品的集合分划成n个或小于n个物品的所有子集,最优解就可以找到。但所有可能划分的总数太大。对适当大的n,找出所有可能的划分要花费的时间是无法承受的。为此,对装箱问题采用非常简单的近似算法,即贪婪法。该算法依次将物品放到它第一个能放进去的箱子中,该算法虽不能保证找到最优解,但还是能找到非常好的解。不失一般性,设n件物品的体积是按从大到小排好序的,即有v0≥v1≥…≥vn-1。如不满足上述要求,只要先对这n件物品按它们的体积从大到小排序,然后按排序结果对物品重新编号即可。装箱算法简单描述如下:
  { 输入箱子的容积;
   输入物品种数n;
   按体积从大到小顺序,输入各物品的体积;
   预置已用箱子链为空;
   预置已用箱子计数器box_count为0;
   for (i=0;i   { 从已用的第一只箱子开始顺序寻找能放入物品i 的箱子j;
   if (已用箱子都不能再放物品i)
   { 另用一个箱子,并将物品i放入该箱子;
   box_count++;
   }
   else
   将物品i放入箱子j;
   }
  }
   上述算法能求出需要的箱子数box_count,并能求出各箱子所装物品。下面的例子说明该算法不一定能找到最优解,设有6种物品,它们的体积分别为:60、45、35、20、20和20单位体积,箱子的容积为100个单位体积。按上述算法计算,需三只箱子,各箱子所装物品分别为:第一只箱子装物品1、3;第二只箱子装物品2、4、5;第三只箱子装物品6。而最优解为两只箱子,分别装物品1、4、5和2、3、6。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值