装箱问题(4月5日)

文章介绍了一种利用动态规划方法解决装箱问题,目标是最小化箱子的剩余空间。将物品体积视为价值,转化为01背包问题,通过遍历所有物品并更新最大可装重量的动态规划数组,最终计算出箱子的最小剩余空间。给出的C++代码实现了这一算法。
摘要由CSDN通过智能技术生成

说明

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

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

输入格式

每个测试文件只包含一组测试数据,每组输入的第一行为一个整数V(0<=V<=20000),表示箱子的容量。

第二行输入一个整数n(0<n<=30),表示有n个物品。

接下来n行,每行输入一个正整数,表示每个物品的体积。

输出格式

对于每组输入数据,输出一个整数,表示箱子剩余空间。

样例

输入数据 1

24
6
8
3
12
7
9
7

Copy

输出数据 1

0

 思路

这道题看似是搜索,但是可以用背包做。

题目要求求出最小的剩余空间,也就是要求出最大的可装重量

这样,我们可以将一个物体的重量当作它的价值,进而将题目转变为一个基本的01背包问题:

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

要求n个物品中,任取若干个装入箱内,使总价值最大。

对于每一个物体,都有两种状态:装 与不装

那么,对于任意重量m的最大价值 dp(j) = max ( dp ( j - v1[i] ) + v1[i], dp(j) )(v1为重量(即价值))

其中,dp ( j - v1[i] ) 指在装了物品i后,箱子的剩余容量能装的最大重量

dp( j - v1[i] ) + v1[i] 指在在装了物品i后,箱子能装的最大重量

代码

#include<bits/stdc++.h>
using namespace std;
int n,v;
int v1[35];
int dp[20010]; 
int main(){
	cin>>v;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>v1[i]; 
	}
for (int i=1; i<=n; i++) {
        for (int j=v; j>=v1[i]; j--) {
            if( dp[j]< dp[j-v1[i]]+v1[i])
                dp[j] = dp[j-v1[i]]+v1[i]; 
            
           
            
    }
}
	
cout<<v-dp[v]; 
	
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值