首页 > 其他 > 详细

ZOJ - 1880 Tug of War

时间:2014-05-11 05:01:04      阅读:375      评论:0      收藏:0      [点我收藏+]

题意:求在两边人数不相差超过1个的情况下,实力尽量相等的情况

思路:从实力和的一半开始类背包操作

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int MAXN = 45010;
const int MAXM = 110;

int a[MAXM];
int dp[MAXN][MAXM];
int n;

int main(){
	int t,flag = 0;
	while (scanf("%d", &n) != EOF){
		int r = n/2;
		if (n & 1)
			r++;
		int sum = 0;
		for (int i = 0; i < n; i++){
			scanf("%d", &a[i]);
			sum += a[i];
		}
		memset(dp,0,sizeof(dp));
		dp[0][0] = 1;
		for (int i = 0; i < n; i++)
			for (int j = sum/2; j >= a[i]; j--)
				for (int k = r; k >= 1; k--)
					if (dp[j-a[i]][k-1])
						dp[j][k] = 1;
		int ans = 0;
		for (int i = sum/2; i >= 0; i--){
			if (n%2 == 0){
				if (dp[i][r]){
					ans = i;
					break;
				}
			}
			if (n%2 == 1){
				if (dp[i][r] || dp[i][r-1]){
					ans = i;
					break;
				}
			}
		}
		printf("%d %d\n", ans, sum-ans);
	}
	return 0;
}



ZOJ - 1880 Tug of War,布布扣,bubuko.com

ZOJ - 1880 Tug of War

原文:http://blog.csdn.net/u011345136/article/details/25487277

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