关注
#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
相关推荐

点赞 评论 收藏
分享
09-16 12:26
陕西师范大学 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 从顶到拉给所有面过的公司评分 #
23526次浏览 192人参与
# 机械人春招想让哪家公司来捞你? #
357840次浏览 3109人参与
# 为了求职,我做过的疯狂伪装 #
13796次浏览 277人参与
# 校招笔试 #
1406次浏览 34人参与
# 职场破冰,你们都聊什么? #
8077次浏览 79人参与
# 晒晒你的中秋福利 #
15831次浏览 120人参与
# 大家实习每天都在干啥 #
89496次浏览 518人参与
# 你的公司给实习生发中秋礼物吗 #
2504次浏览 31人参与
# 机械笔面试考察这些知识点 #
10903次浏览 96人参与
# bilibili求职进展汇总 #
91549次浏览 820人参与
# 工作压力大怎么缓解 #
105664次浏览 1053人参与
# 秋招OC许愿 #
347642次浏览 2531人参与
# 广联达求职进展汇总 #
11466次浏览 50人参与
# 机械人怎么评价今年的华为 #
209427次浏览 1525人参与
# 宣讲会你有哪些意向不到的收获 #
1950次浏览 23人参与
# 聊聊这家公司值得去吗 #
561252次浏览 3717人参与
# 你面试被问到过哪些不会的问题? #
23640次浏览 848人参与
# 百度秋招提前批进度 #
151249次浏览 1772人参与
# 电网笔面经互助 #
47188次浏览 431人参与
# 秋招的嫡长offer #
33213次浏览 299人参与