首页 > 其他 > 详细

UVa 10664 - Luggage

时间:2015-06-30 00:09:39      阅读:106      评论:0      收藏:0      [点我收藏+]

题目:有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;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

UVa 10664 - Luggage

原文:http://blog.csdn.net/mobius_strip/article/details/46687993

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!