装箱问题的三种解法

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

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

样例
输入样例
复制代码
24
6
8
3
12
7
9
7
输出样例
复制代码
0

方法一:动规

dp[j]表示体积为j用掉的最大体积

动态转移方程:dp[j]=max(dp[j],dp[j-a[i]]+a[i]);

dp[j-a[i]]+a[i]表示a[i]全部装入

dp[j]表示不放入

cs 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
int main(){
	int V,n,i,j;
	cin>>V>>n;
	int a[35]={};
	for(i=0;i<n;i++){
		cin>>a[i];
	}
	int dp[20005]={};
	for(i=0;i<n;i++){
		for(j=V;j>=a[i];j--){
			dp[j]=max(dp[j],dp[j-a[i]]+a[i]);
		}
	}
	cout<<V-dp[V]<<endl;
} 

方法2 回溯

cs 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
int a[35]={}; 
//maxV表示消耗的最大体积 
int maxV=0,n,V;
//sumV为实际消耗的体积 
//cnt为搜索的第cnt个物品 
void dfs(int cnt,int sumV){
	if(sumV>V)return;
	//搜索到最后一个 
	if(cnt==n+1){
		if(sumV>maxV)maxV=sumV;
		return; 
	}
	//不放入 
	dfs(cnt+1,sumV);
	//全部放入 
	dfs(cnt+1,sumV+a[cnt]);
}
int main(){
	cin>>V;
	int i,j;
	cin>>n; 
	for(i=0;i<n;i++){
		cin>>a[i]; 
	}
	dfs(0,0);
    cout<<V-maxV<<endl;
} 

方法3 贪心

从大到小排序,每次选择可以装入的

cs 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
//从大到小排序 
int cmp(const void *a,const void *b){
	return *(int*)b-*(int*)a;
} 
int main(){
	int V,n,i,j;
	cin>>V>>n;
	int a[35]={};
	for(i=0;i<n;i++){
		cin>>a[i];
	}
	qsort(a,n,sizeof(int),cmp);
	for(i=0;i<n;i++){
		if(V==0)break;
		if(V>=a[i])V-=a[i]; 
	}
	cout<<V<<endl; 
} 

这样子有局限性,只有数组最大值放入能够使剩余空间最小才满足。

举个例子

数组最大值放入反而得不到剩余空间最小值

用动态规划和回溯均可得到最小剩余空间为0。可见这个贪心策略有局限性。

相关推荐
焦糖玛奇朵婷6 分钟前
就医陪诊小程序|从软件开发视角看实用度✨
java·大数据·jvm·算法·小程序
你撅嘴真丑20 分钟前
求10000 以内的阶乘 与 字符串最大跨距
数据结构·c++·算法
Figo_Cheung21 分钟前
Figo几何基础论:基于集合几何化的统一理论框架与哲学意涵——首次提出“几何化诱导的全息原理”
算法·机器学习·概率论·迭代加深
lingzhilab26 分钟前
零知IDE—— ESP8266(ESP-12F)MESH 组网实现多设备智能家居控制系统(灯光 / 传感器 / 人体感应)
c++·ide·智能家居
小y要自律30 分钟前
11 string容器 - 子串获取
c++·算法·stl
t1987512831 分钟前
三相计量芯片RN8302B驱动校正程序设计与实现
算法
期末考复习中,蓝桥杯都没时间学了35 分钟前
力扣刷题9
算法·leetcode·职场和发展
DevangLic36 分钟前
【确认是否安装了 C++ 工具】
android·java·c++
砚边数影40 分钟前
线性回归原理(二):梯度下降算法,Java实现单变量/多变量拟合
java·数据库·算法·线性回归·kingbase·kingbasees·金仓数据库
承渊政道44 分钟前
C++学习之旅【C++拓展学习之反向迭代器实现、计算器实现以及逆波兰表达式】
c语言·开发语言·c++·学习·visual studio