关注
#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
相关推荐
查看6道真题和解析 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 我是面试官,请用一句话让我破防 #
15977次浏览 100人参与
# 美团开奖 #
183232次浏览 969人参与
# 快手技术岗信息交流阵地 #
15695次浏览 82人参与
# 校招生月薪1W算什么水平 #
15210次浏览 112人参与
# 中美关税战对我们有哪些影响 #
37716次浏览 306人参与
# i人适合做什么工作 #
7822次浏览 81人参与
# “vivo”个offer #
32946次浏览 247人参与
# 读研or工作,哪个性价比更高? #
75178次浏览 762人参与
# 华为保温 #
102351次浏览 383人参与
# 哪些瞬间让你真切感受到了工作的乐趣 #
17162次浏览 79人参与
# 小厂实习有必要去吗 #
69863次浏览 344人参与
# 哪些行业值得去? #
2837次浏览 40人参与
# 秋招什么时候开投比较合适? #
109767次浏览 807人参与
# 如果秋招能重来,我会____ #
29543次浏览 255人参与
# 华为池子有多大 #
107405次浏览 748人参与
# 美团求职进展汇总 #
2805908次浏览 23836人参与
# 上班后和你想的一样吗? #
87412次浏览 666人参与
# 苦尽甘来时,再讲来时路 #
26237次浏览 359人参与
# 为了实习逃课值吗? #
23085次浏览 213人参与
# 大家实习每天都在干啥 #
97061次浏览 536人参与
# 工作压力大怎么缓解 #
119625次浏览 1112人参与
# 如果上班像打游戏,你最想解锁什么技能 #
5545次浏览 55人参与
