标签:
题目:有m个行李每个有一个重量,分装到两辆车上问能否重量均分。
分析:dp,01背包。取总和的一半01背包即可。
说明:好久没有做dp了。
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
using namespace std;
int w[22],f[202];
int main()
{
int n;
char ch;
while (~scanf("%d%c",&n,&ch))
while (n --) {
int count = 0,sum = 0;
while (~scanf("%d%c",&w[count],&ch) && ch == ' ')
sum += w[count ++];
sum += w[count ++];
for (int i = 0; i <= sum; ++ i)
f[i] = 0;
f[0] = 1;
for (int i = 0; i < count; ++ i)
for (int j = sum; j >= w[i]; -- j)
if (f[j-w[i]])
f[j] = 1;
if (sum%2 || !f[sum/2])
printf("NO\n");
else printf("YES\n");
}
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/mobius_strip/article/details/46687993