动态规划专题(一)——状压DP
undefined
前言
最近,决定好好恶补一下我最不擅长的DP。
动态规划的种类还是很多的,我就从 状压DP 开始讲起吧。
简介
状压DP应该是一个比较玄学的东西。
由于它的时间复杂度是指数级的(但也足以吊锤DFS),所以状压DP题的数据范围一般都巨小。
前置技能:位运算
要想学习状压DP,最好先去学一学位运算及其简单变换操作,因为位运算在状压DP中起到了很重要的作用。
核心思想
状压DP的核心思想在于用一个变量state(0≤state<2N)来存储当前状态,而state二进制下的每一位都存储了一个信息:当前元素是否使用过。
当然,还有一些比较恶心的三进制、四进制状压DP,主要思想和二进制是差不多的。
几道例题
其实,状压DP的主要内容大致也就是上面这些,下面放几道例题吧:
第一道例题:【BZOJ1076】[SCOI2008] 奖励关
一道比较恶心的期望DP。注意,期望一定要倒着推啊!不然就会像我一样调死。
第二道例题:【BZOJ1087】[SCOI2005] 互不侵犯King
一眼看去觉得是搜索,优化了很久之后才发现是状压DP。
第三道例题:【洛谷4772】灰化肥,会挥发
先BFS预处理,然后状压DP即可。
待到再迷茫时回头望,所有脚印会发出光芒
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 《HelloGitHub》第 108 期
· Windows桌面应用自动更新解决方案SharpUpdater5发布
· 我的家庭实验室服务器集群硬件清单
· C# 13 中的新增功能实操
· Supergateway:MCP服务器的远程调试与集成工具