动态规划——买书问题

这是一篇关于使用动态规划解决买书折扣问题的博客。博主详细介绍了如何利用动态规划算法来找到购买不同卷书的最低花费。通过将问题分解为子问题,并设置状态转移方程,最终得出购买每卷书的最优策略。

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

题目

      有一书店引进了一套书,共有3卷,每卷书定价是60元,书店为了搞促销,推出一个活动,活动如下:
      
       如果单独购买其中一卷,那么可以打9.5折。
       如果同时购买两卷不同的,那么可以打9折。
       如果同时购买三卷不同的,那么可以打8.5折。
      
       如果小明希望购买第1卷x本,第2卷y本,第3卷z本,那么至少需要多少钱呢?(x、y、z为三个已知整数)。

思路

首先三卷书的价格一样,因此三卷书可以无差别对待,比如买3本第一卷,2本第二卷和1本第三卷,和买1本第一卷,2本第二卷,三本第三卷属于同一种情况。

1.一次买书过程可以买三本、两本或一本。而每经过一次选择,剩下的问题又变成给定一定数量的书,求花钱最少的方案。即原问题可以分解为若干子问题。

2.状态转移方程

用函数MinMoney(i,j,k)求买书i,j,k本时的最优解

设minMoney(i,j,k)为当购买i本一卷,j本二卷,k本三卷时的最小花费。

设i<=j<=k

minMoney(i,j,k)=min{

    minMoney(i-1,j-1,k-1)+3*60*0.85,       (购买三卷各一本)

    minMoney(i,j-1,k-1)+2*160*0.9,      

买书问题 dp实现 题目:买书书店引进一套有3,每定价60书店为了销,推出个活动,活动如下: 如果单独购买其中,那么可以打9.5折。 如果同时购买两不同的,那么可以打9折。 如果同时购买三不同的,那么可以打8.5折。 如果小明希望购买第1x本,第2y本,第3z本,那么至少需要多少钱呢?(x、y、z为三个已知整数)。 1、过程为次的购买,每次购买也许只买本(这有三种方案),或者买两本(这也有三种方案), 或者三本起买(这有种方案),最后直到买完所有需要的。 2、最后步我必然会在7种购买方案中选择种,因此我要在7种购买方案中选择个最佳情况。 3、子问题是,我选择了某个方案后,如何使得购买剩余的能用最少的钱?并且这个选择不会使得剩余的为负数 。母问题问题都是给定三的购买量,求最少需要用的钱,所以有"子问题重叠",问题中三个购买量设置为参数, 分别为i、j、k。 4、的确符合。 5、边界是次购买就可以买完所有的,处理方式请读者自己考虑。 6、每次选择最多有7种方案,并且不会同时实施其中多种,因此方案的选择互不影响,所以有"子问题独立"。 7、我可以用minMoney[i][j][k]来保存购买第1i本,第2j本,第3k本时所需的最少金钱。 8、有x * y * z个问题,每个问题面对7种选择,时间为:O( x * y * z * 7) = O( x * y* z )。 9、用函数MinMoney(i,j,k)来表示购买第1i本,第2j本,第3k本时所需的最少金钱,那么有: MinMoney(i,j,k)=min(s1,s2,s3,s4,s5,s6,s7),其中s1,s2,s3,s4,s5,s6,s7分别为对应的7种方案使用的最少金钱: s1 = 60 * 0.95 + MinMoney(i-1,j,k) s2 = 60 * 0.95 + MinMoney(i,j-1,k) s3 = 60 * 0.95 + MinMoney(i,j,k-1) s4 = (60 + 60) * 0.9 + MinMoney(i-1,j-1,k) s5 = (60 + 60) * 0.9 + MinMoney(i-1,j,k-1) s6 = (60 + 60) * 0.9 + MinMoney(i-1,j,k-1) s7 = (60 + 60 + 60) * 0.85 + MinMoney(i-1,j-1,k-1)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值