算法:状态压缩

本文介绍了在编程中如何使用状态压缩技术来优化内存使用,特别是在处理路径选择和组合问题时。通过将选择的元素映射到二进制数上,可以更高效地跟踪已选状态,并减少了不必要的内存开销。文章通过示例解释了如何判断元素是否被选取,以及如何修改状态。同时,还提供了一些适合使用状态压缩算法的算法题目,如526.优美的排列和847.访问所有节点的最短路径,帮助读者实践这一技巧。
摘要由CSDN通过智能技术生成

       在刚开始学习代码时,我们通常会创建一个数组或者map来标记一些我们已经选择过的值或者对象。但是在面对一些路径问题,组合问题,且处理的对象数量较少时,数组不仅不方便且要浪费一定内存。

 状态压缩

面对以上问题,我们可以利用一个二进制数state来代表所走的路径或者组合方案,每一位数就代表着一个元素

例如:有A B C D E5个元素
我们用 5位的二进制数来代表 这5个元素
① 当A被选取时 二进制数状态:00001

② 当A,B同时被选取时 二进制数状态:00011

于是我们可以推导出以下式子

/**查看元素k是否被选取**/
int n = (state>>k)&1;
n == 1; //已被选取
n == 0; //未被选取

/**查看元素k选择前的状态**/
state = state^(1<<k);

练手算法题

于是我们便可以借助状态压缩来处理一些路径问题以及组合问题

526.优美的排列
847.访问所有节点的最短路径

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值