问题 A: 装箱问题
时间限制: 1 Sec 内存限制: 128 MB
献花: 49 解决: 32
[献花][花圈][TK题库]
题目描述
【问题描述】
有一个箱子的容量为V(V为正整数,且满足0≤V≤20000),同时有n件物品(0的体积值为正整数。
要求从n件物品中,选取若干装入箱内,使箱子的剩余空间最小。
输入:1行整数,第1个数表示箱子的容量,第2个数表示有n件物品,后面n个数分别表示这n件
物品各自的体积。
输出:1个整数,表示箱子剩余空间。
【输入输出样例】
输入:
24 6 8 3 12 7 9 7
输出:
0
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
const int MaxN = 100000;
int main()
{
#ifdef _DEBUG
freopen("data.txt", "r+", stdin);
#endif // _DEBUG
std::ios::sync_with_stdio(false);
int V, n, dp[MaxN], vol[MaxN];
while (cin >> V >> n)
{
for (int i = 0; i <= V; ++i)
dp[i] = 0;
for (int i = 1; i <= n; ++i)
cin >> vol[i];
for (int i = 1; i <= n; ++i)
{
for (int v = V; v >= vol[i]; --v)
if (vol[i] <= v)
dp[v] = max(dp[v], dp[v - vol[i]] + vol[i]);
}
cout << V - dp[V] << endl;
}
return 0;
}
/**************************************************************
Problem: 24338
User: Sharwen
Language: C++
Result: 升仙
Time:11 ms
Memory:2360 kb
****************************************************************/