POJ 1260

注意1,把条件判断转换成min或max

注意2,如果没有递推递归,那就是贪心了。贪心不回溯,never reconsider its choice.

这道题最开始想的其实是贪心,如果num[i-1]*a[i]<10*a[i-1]那么就把i-1用i买,把数目加到i上num[i] += num[i-1]

这不是DP,而是贪心,实际上贪心是不对的。因为i-1加到i,然后如果i再加到i+1,实际上做了i-1加到i+1的过程,那就不一定num[i-1]*a[i+1]<10*a[i-1]了。

局部最优解没法保证全局最优解,没有reconsider its choice。

同时在想这个贪心的时候想到了只能是i-1加到i上,不能i-1加到i+1上,不能跳着加,那样肯定不是最有的。因为i+1的价格比i高

 

其实想到了贪心,那么扩展一下,并且把条件判断替换成min在这里。

那么就是加入一个递推过程,d[i] = min{d[j] + (sum(i) - sum(j) + 10)*a[i]}  0<= j <i

就是递推了,就是遍历减少重复计算。

sum(i)是前i个数量和

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值