求币值最大化问题---动态规划(附C++代码)

通过动态规划解决一种特殊条件下的硬币选择问题,要求选择的硬币在原始位置上互不相邻,目标是使总金额最大化。文章介绍了问题的抽象、模拟过程,并给出状态转移方程及C++代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

给定一排n个硬币,其面值均为正整数c1,c2,…,cn,这些整数并不一定两两不同。请问如何选择硬币,使得在其原始位置互不相邻的条件下,所选硬币的总金额最大

抽象后

要求从一个连续正整数数组中取若干个元素, 每个元素都不相邻, 且元素和最大

因为每个元素值都是正整数, 所以能多取一个元素, 就多取一个, 能取大的, 就取大的

模拟

用动态规划求解这个问题时, 我们先来分析一下, 然后获取状态转移方程
在这里插入图片描述
假设我们从左到右取硬币
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值