-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy path10032-Tug of War.cpp
34 lines (33 loc) · 1011 Bytes
/
10032-Tug of War.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include <bits/stdc++.h>
using namespace std;
// knapsack/subset sum trick when n<=64, we can use bitmask
int main()
{
int tc,n,v;
scanf("%d",&tc);
while(tc--){
scanf("%d",&n);
int sum=0;
vector<int> weights;
for(int i=0;i<n;i++){
scanf("%d",&v);
weights.push_back(v);
sum+=v;
}
int half_sum = sum/2;
int half_ppl = n/2;
// dp bitmask, each bit i representing whether i people can form it
vector<long long> dp(half_sum+1);
dp[0]=1;
for(int i=0;i<n;i++)
for(int j=half_sum;j>=weights[i];j--)
dp[j] |= (dp[j-weights[i]] << 1LL); // shift one as dp[n][j] |= dp[n-1][j-weights[i]]
int best=-1;
for(int i=half_sum;i>=0&&best==-1;i--){
if(dp[i] & (1LL<<half_ppl)) best=i;
else if(n%2 && dp[i] & (1LL<<(half_ppl+1))) best=i;
}
printf("%d %d\n",best,sum-best);
if(tc) printf("\n");
}
}