装载问题
题目描述
有一批共n个集装箱要装上艘载重量为c的轮船,其中集装箱i的重量为wi。找出一种最优装载方案,将轮船尽可能装满,即在装载体积不受限制的情况下,将尽可能重的集装箱装上轮船。
输入
由文件load.in给出输入数据。第一行有2个正整数n和c。n是集装箱数,c是轮船的载重量。接下来的1行中有n个正整数,表示集装箱的重量。
输出
将计算出的最大装载重量输出到文件load.out。
样例输入
5 10
7 2 6 5 4
样例输出
10
这道题比较难, 在我的字典里根本就没有“难”字
上源代码:
#include<bits/stdc++.h>
using namespace std;
int maxx,ans,n,c,sz[10000];
void ss(int i,int k=0) {
if(maxx>c) return ;
if(k==i+1) {
ans=max(ans,maxx);
return ;
}
if(maxx+sz[k]<=c) {
maxx+=sz[k];
ss(i,k+1);
maxx-=sz[k];
}
ss(i,k+1);
}
int main() {
cin>>n>>c;
for(int i=1; i<=n; i++) cin>>sz[i];
sort(sz+1,sz+n+1);
ss(n);
cout<<ans<<endl;
return 0;
}