状态压缩dp

 
参考blog  侵删 
https://blog.csdn.net/qq_43326267/article/details/86682525

https://blog.csdn.net/u011077606/article/details/43487421

有状态后需要对状态进行操作或访问 通过位运算

1
.’&’符号,x&y,会将两个十进制数在二进制下进行与运算,然后返回其十进制下的值。例如3(11)&2(10)=2(10)。 2.’|’符号,x|y,会将两个十进制数在二进制下进行或运算,然后返回其十进制下的值。例如3(11)|2(10)=3(11)。 3.’^’符号,x^y,会将两个十进制数在二进制下进行异或运算,然后返回其十进制下的值。例如3(11)^2(10)=1(01)。 4.’<<’符号,左移操作,x<<2,将x在二进制下的每一位向左移动两位,最右边用0填充,x<<2相当于让x乘以4。

相应的,’>>’是右移操作,x>>1相当于给x/2,去掉x二进制下的最有一位。 这四种运算在状压dp中有着广泛的应用,常见的应用如下: 1.判断一个数字x二进制下第i位是不是等于1。 方法:if ( ( ( 1 << ( i - 1 ) ) & x ) > 0) 将1左移i-1位,相当于制造了一个只有第i位上是1,其他位上都是0的二进制数。然后与x做与运算,如果结果>0,说明x第i位上是1,反之则是0。 2.将一个数字x二进制下第i位更改成1。 方法:x = x | ( 1<<(i-1) ) 证明方法与1类似,此处不再重复证明。 3.把一个数字二进制下最靠右的第一个1去掉。 方法:x=x&(x-1) --------------------- 版权声明:本文为CSDN博主「qxAi」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/u011077606/article/details/43487421
https://www.cnblogs.com/Tony-Double-Sky/p/9283254.html
通过题目要求减少状态量
这可以说是状压的一大精华了。一般状压的题目会有大量的状态,枚举所有状态则需要大量的时间,

时间承受不了,若和dp结合起来,dp数组开个三四维,空间也吃不消。 所以我们可以通过预处理状态,去掉不合法的状态,减少时空的需要 具体实现和STL中的map很相似:我们用一个序号来映射状态,
开一个数组INDEX[ ](这里有坑,小写的index会和cstring库冲突,)

INDEX[i]表示第i个合法的状态是什么,然后枚举的时候直接枚举INDEX数组就好了
 
  

 

 
https://blog.csdn.net/qq_40859951/article/details/81872148
def:

状压是利用计算机二进制的性质来描述状态的一种DP方式

使用:


 

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://www.cnblogs.com/jjjjjjy/p/11352000.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值