2023年8月1日发(作者:)
带负值的背包问题poj21841:选的⽜要保证两个属性和都要⼤于0。2.总和最⼤!想到什么。01背包,⼀个数要么不⽤,要么⽤,让价值最⼤。因为会出现负值,并且两个值均⼤于0 ,那么假设第⼀种属性已经⼤于0了--重新设置0点,让100*1000为0点,过了这个点,就说明选的第⼀个属性和⼤于0了,反之则没有。那么这时候就只需要管第⼆种的属性了。把第⼀种当做消耗来算,第⼆种属性来算价值(相当于只有花费a,才能得到b。因为a已经在坐标体现了。⼩于100000就为负,否则为正),进⾏DP。那么算出来就需要看dp值是否⼤于0了。01背包⼀维DP是倒序的。但是当a[i]为负数时,如果依旧倒序,反⽽递推式没有往⼩跑,因为是dp【j-a[i]】,a【i】为负,j-a反⽽变⼤。#include#include#include#include#include#include#include#include#include#include#include
2023年8月1日发(作者:)
带负值的背包问题poj21841:选的⽜要保证两个属性和都要⼤于0。2.总和最⼤!想到什么。01背包,⼀个数要么不⽤,要么⽤,让价值最⼤。因为会出现负值,并且两个值均⼤于0 ,那么假设第⼀种属性已经⼤于0了--重新设置0点,让100*1000为0点,过了这个点,就说明选的第⼀个属性和⼤于0了,反之则没有。那么这时候就只需要管第⼆种的属性了。把第⼀种当做消耗来算,第⼆种属性来算价值(相当于只有花费a,才能得到b。因为a已经在坐标体现了。⼩于100000就为负,否则为正),进⾏DP。那么算出来就需要看dp值是否⼤于0了。01背包⼀维DP是倒序的。但是当a[i]为负数时,如果依旧倒序,反⽽递推式没有往⼩跑,因为是dp【j-a[i]】,a【i】为负,j-a反⽽变⼤。#include#include#include#include#include#include#include#include#include#include#include
发布评论