码迷,mamicode.com
首页 > 其他好文 > 详细

UVa 10664 - Luggage

时间:2015-06-30 00:12:21      阅读:137      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!