关注
#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
相关推荐
牛客热帖
更多
正在热议
更多
# 秋招什么时候开投比较合适? #
23583次浏览 318人参与
# 百度工作体验 #
223320次浏览 1971人参与
# 现代汽车前瞻技术研发急速编程挑战赛 #
27889次浏览 216人参与
# 机械人与华为的爱恨情仇 #
117088次浏览 946人参与
# 发工资后,你做的第一件事是什么 #
68135次浏览 229人参与
# 机械人集合!你是什么工程师? #
15791次浏览 89人参与
# 你觉得实习能学到东西吗 #
36158次浏览 711人参与
# 找不到好工作选择GAP真的丢人吗 #
78234次浏览 938人参与
# 我想去国央企的原因 #
59971次浏览 393人参与
# 如何准备秋招 #
20547次浏览 390人参与
# 工作中哪个瞬间让你想离职 #
25884次浏览 177人参与
# 入职第四天,心情怎么样 #
29420次浏览 417人参与
# 拼多多工作体验 #
28527次浏览 197人参与
# 多益网络求职进展汇总 #
29204次浏览 134人参与
# 快手求职进展汇总 #
547041次浏览 6001人参与
# 硬件应届生薪资是否普遍偏低? #
74064次浏览 514人参与
# 不考虑转正,实习多久合适 #
32263次浏览 145人参与
# 面试中,你被问过哪些奇葩问题? #
68536次浏览 796人参与
# 你们公司几号发工资 #
21192次浏览 140人参与
# 如果再来一次,你还会学硬件吗 #
125728次浏览 1402人参与
# 实习,不懂就问 #
46258次浏览 693人参与