【按位DP】

按位DP以我的理解就是在区间[A,B]内求出满足某种性质的数的个数或是最值。例如统计区间[A,B]内不含前导零且相邻两个数字之差至少为2的正整数这类问题都可以用按位DP解决。

一般来说按位DP肯定有一维状态是表示当前规划到数字的前i位,那么处理i+1位的所有状态时有两种情况:1.前i位不是上下界,这样第i+1位可以取任何数。2.前i位是上下界,如果是上界的话,第i+1位就只能取小于等于上界B第i+1位的数。这样按位dp就可以加一维状态表达是否达到边界来处理这两种情况。再根据问题加若干维来处理不同的性质即可实现按位DP。

HDU 3555

http://acm.hdu.edu.cn/showproblem.php?pid=3555

假如求不包含49的数有多少个。对于前i位结尾有三种情况4结尾,49结尾,其他情况,这三个状态可以构造一个自动机,那么状态转移时保证4结尾的状态不转换到49结尾即可,有点类似自动机DP。

HDU 3709

http://acm.hdu.edu.cn/showproblem.php?pid=3709

多出两维状态表示轴的位置和前i位的weight差即可,注意0因为轴的位置不同重复计数的细节。

HDU 3565

http://acm.hdu.edu.cn/viewcode.php?rid=3354696

细节比较多,我用7个状态描述前i位已经形成了bi-peak哪些部分(0 , _ , _/ , _/\ , _/\_ , _/\_/ , _/\_/\) ,建立七个状态间的转换关系。由于是求最值,不能通过区间相减的方法,需要直接通过上下界来dp,用2个二进制位来表示是否达到上界和下界来实现。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值