关注
渣银选手来答一发。这题有一个分组背包的思路,请看下面的表: . . . . . ... ... ... 假设答案为 那么它等价于 相信聪明的你已经发现了,如果答案存在,则存在从上面的表的每一列选择一个数字,它们的和为 0。所以这就变成了一个简单的分组背包的问题了。当然实现时需要避开一个小bug,也就是上面的表全选0的情况,还有,统计和的时候也得想想办法。anyway,这是我的代码: # include <bits/stdc++.h>
using namespace std;
const int N = 100 + 5;
const int M = 2000 + 5;
bool dp[N][3][M * 4]; //dp[i][0/1/2][j] = (0/1) 表示前i个里面(0: 选择+a[i] 1: 选择-a[i] 2: 不选第i个数字)之后是否能凑成总和j
int sum[N][3][M * 4]; //记录一下路径上正数的和,便于统计答案
int a[N];
int f(int x) //因为可能出现负数下标,所以做这个处理
{
return x + 4000;
}
int main ()
{
int n;
cin >> n;
for (int i = 1; i <= n; ++i) cin >> a[i];
dp[0][2][f(0)] = true;
for (int i = 0; i < n; ++i) {
for (int j = 0; j <= 2; ++j) {
for (int k = f(-2000); k <= f(2000); ++k) {
if (dp[i][j][k] == false) continue;
dp[i+1][0][k + a[i+1]] = true;
sum[i+1][0][k + a[i+1]] = max(sum[i+1][0][k + a[i+1]], sum[i][j][k] + a[i+1]);
dp[i+1][1][k - a[i+1]] = true;
sum[i+1][1][k - a[i+1]] = max(sum[i+1][1][k - a[i+1]], sum[i][j][k]);
dp[i+1][2][k] = true;
sum[i+1][2][k] = max(sum[i+1][2][k], sum[i][j][k]);
}
}
}
for (int i = 0; i <= 2; ++i) {
if (dp[n][i][f(0)] == true && sum[n][i][f(0)] != 0) { // 之所以 sum[n][i][f(0)] != 0 是为了排除全都不选的特殊情况
cout << sum[n][i][f(0)];
return 0;
}
}
cout << "Impossible" << endl;
return 0;
} 看懂点个赞哈~
查看原帖
点赞 评论
相关推荐
03-26 15:22
吉林大学 游戏后端 点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 你的实习产出是真实的还是包装的? #
19755次浏览 342人参与
# 中国电信笔试 #
31531次浏览 284人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
14788次浏览 218人参与
# 春招至今,你的战绩如何? #
63335次浏览 574人参与
# 如果秋招能重来,我会____ #
96873次浏览 500人参与
# 一张图晒出你司的标语 #
4146次浏览 74人参与
# 厦门银行科技岗值不值得投 #
7783次浏览 186人参与
# i人适合做什么工作 #
37098次浏览 124人参与
# 我是面试官,请用一句话让我破防 #
79681次浏览 219人参与
# 金三银四,你的春招进行到哪个阶段了? #
21968次浏览 280人参与
# 哪些公司真双非友好? #
69490次浏览 287人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
340518次浏览 2170人参与
# AI面会问哪些问题? #
26915次浏览 537人参与
# 找AI工作可以去哪些公司? #
8636次浏览 218人参与
# 从事AI岗需要掌握哪些技术栈? #
8535次浏览 285人参与
# 面试尴尬现场 #
220932次浏览 861人参与
# 五一之后,实习真的很难找吗? #
102875次浏览 584人参与
# 你做过最难的笔试是哪家公司 #
32258次浏览 216人参与
# 应届生第一份工资要多少合适 #
20636次浏览 86人参与
# 聊聊你的职场新体验 #
336327次浏览 1894人参与
# 你小时候最想从事什么职业 #
159966次浏览 2072人参与
# 阿里笔试 #
177970次浏览 1307人参与