蓝桥杯c语言算法提高质数,蓝桥杯练习系统算法提高 求最大值(示例代码)

该博客主要介绍了一个使用动态规划解决的数对求和问题。代码中定义了一个结构体`Node`来存储数对,通过初始化二维数组`dp`来存储中间状态,并逐步更新最大值`ans`。在遍历过程中,根据数对的和更新`dp`数组,最终找出最大和。这是一个典型的动态规划应用实例。
摘要由CSDN通过智能技术生成

#include

#include

#include

using namespace std;

#define inf 1000000000

struct Node {

int a, b;

}node[210];

int dp[210][200010]; //dp[i][j] = sum 表示的是 考虑前i对数 第i对数被选中时 所有的ai和为j时 所有的bi和为sum。

// dp[i][j] = max(dp[i][j], dp[k][sumb]+node[i].b); (0<=k<=i-1);

int main() {

int n;

while(cin >> n) {

int suma = 0;

for (int i=0; i

cin >> node[i].a >> node[i].b;

suma = max(suma, suma+node[i].a);

}

suma +=100000;

for (int i=0; i

for (int j=0; j<200010; ++j) {

dp[i][j] = -inf;

}

}

dp[0][100000+node[0].a] = node[0].b;

int ans = 0; // 讲道理啊,如果ans初始值是-inf,就是75分,如果是0就是100分了。

if (node[0].a >= 0 && node[0].b >= 0)

ans = max(ans, node[0].a+node[0].b);

for (int i=1; i

dp[i][node[i].a+100000] = node[i].b;

for (int j=0; j

for (int k=0; k<=suma; ++k) {

if (dp[j][k] != -inf) {

if (k + node[i].a < 0) continue;

dp[i][k+node[i].a] = max(dp[i][k+node[i].a], dp[j][k]+node[i].b);

if (k+node[i].a >= 100000 && dp[i][k+node[i].a] >= 0) {

ans = max(ans, k+node[i].a-100000+dp[i][k+node[i].a]);

}

}

}

}

}

cout << ans << endl;

}

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值