关注
#include <bits/stdc++.h>
#include <thread>
#define input freopen("input.txt", "r", stdin)
#define output freopen("output.txt", "w", stdout)
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define random(x) (rand()%x)+1
using namespace std;
const int maxn=1e5+5;
using LL =long long;
const int inf = 0x3f3f3f3f;
const int mod=1e6+3;
int dp[51][maxn/2];
int main(int argc, char const *argv[])
{
input;output;
int T,n,arr[101],sum;
scanf("%d",&T);
while(T--){
sum=0;
scanf("%d",&n);
assert(n<=100);
for(int i=0;i<n;i++){
scanf("%d",arr+i);
sum+=arr[i];
}
assert(sum<maxn);
for(int i=0;i<=(n+1)/2;i++)
for(int j=0;j<=sum/2;j++)
dp[i][j]=-inf;
dp[0][0]=0;
for(int i=0;i<n;i++)
for(int j=(n+1)/2;j>0;j--)
for(int k=sum/2;k>=arr[i];k--)
dp[j][k]=max(dp[j][k],dp[j-1][k-arr[i]]+arr[i]);
int ans=0;
for(int i=0;i<=sum/2;i++)
ans=max(ans,max(dp[n/2][i],dp[(n+1)/2][i]));
printf("%d %d\n",ans,sum-ans);
}
return 0;
} 第三题是背包,问题等价于求n/2或者(n+1)/2个人放入总战斗力和1/2的背包中,看最多能放入多少战斗力,话说求第二题的思路
查看原帖
点赞 3
相关推荐
牛客热帖
正在热议
# 25届秋招总结 #
261980次浏览 2169人参与
# 0offer是寒冬太冷还是我太菜 #
886680次浏览 7906人参与
# 北方华创开奖 #
23599次浏览 260人参与
# 地方国企笔面经互助 #
2823次浏览 7人参与
# 学历or实习经历,哪个更重要 #
43234次浏览 327人参与
# 选完offer后,你后悔学本专业吗 #
13049次浏览 94人参与
# 查收我的offer竞争力报告 #
19151次浏览 251人参与
# 应届生被毁约被毁意向了怎么办 #
28079次浏览 243人参与
# 你最想要的公司福利是? #
41720次浏览 144人参与
# 如何一边实习一边秋招 #
987047次浏览 12609人参与
# 一觉醒来,我觉醒了超级打工人系统 #
3263次浏览 36人参与
# 嵌入式转岗的难度怎么样 #
11183次浏览 250人参与
# 你最希望上岸的公司是? #
76349次浏览 469人参与
# 如何写一份好简历 #
604731次浏览 8502人参与
# 面试体验感最好的是哪家? #
83558次浏览 816人参与
# 机械应届生薪资要多少才合适? #
12531次浏览 61人参与
# 牛客十周岁生日快乐 #
48652次浏览 759人参与
# 你认为第一份工作重要吗 #
5415次浏览 49人参与
# 985本硕1个中小厂offer,摆烂or继续努力 #
79808次浏览 589人参与
# 秋招OC许愿 #
227959次浏览 1878人参与
# 来聊聊机械薪资天花板是哪家 #
65455次浏览 443人参与