帮助:大毒瘤!!!调了我2h,拍了我2h,最后没调出来,重写才AC。wdnmd。

思路

这题主要是线性 dp ,而状压 dp 只是最后在统计答案时的一个辅助。

首先定义 \(dp[i][j][k]\) 为考虑前 \(i\) 本书,已经抽出来了 \(j\) 本,最后没被抽出来的一本书是高度 \(k\) 的最小混乱度。

每次放入的书与最后一位不同的时候我们把答案 \(+1\) 。

但是这样有一个弊端,就是当我们取出一些书后,还要放回去。我们自然是要放到那些没拿出来的同高度的书里面,但是如果一种高度的书全拿出来了,我们就必须加上那些全拿出来的书的种数。

观察到书本高度只能在 \([25,32]\) 这个区间里,有 \(8\) 种高度,所以我们考虑把所有书的高度 \(-25\) 后状压。

重新定义 \(dp[i][j][k][l]\) 表示考虑前 \(i\) 本书,已经抽出来 \(j\) 本,此时没被拿出来的书的状态为 \(k\) ,放在书架里的最后一本书的类型为 \(l\) 时的最小混乱度。

于是可以分两种情况转移:

  • 对于不把这本书拿出来的情况:
\[dp[i][j][k|(a[i])][a[i]]=\min(dp[i][j][k|(a[i])][a[i]],dp[i-1][j][k][l]+(a[i]!=l))
\]

这里 \(k|(a[i])\) 的原因是要把它放进去。后面 \((a[i]!=l)\) 的原因是如果高度不同,混乱度要 \(+1\) 。

  • 对于把这本书拿出来的情况:
\[dp[i][j+1][k][l]=\min(dp[i][j+1][k][l],dp[i-1][j][k][l])
\]

在 dp 完成之后,我们最后枚举后三维,并且让最终状态 \(((st \oplus p)\&p)\) ,就可以求出书架里少了哪些书,把少的书的个数加上即可,最后求个 \(\min\) 。注意提前预处理出每个二进制数 \(1\) 的个数减小常数。

最后观察到空间开销大,并且每次转移只会用到 \(i-1\) 里的数,所以考虑滚动数组优化 dp 。

同时注意提前把不合法的情况排除掉,可以减小部分常数。

代码

#include <bits/stdc++.h>
using namespace std;
int dp[2][105][260][15],a[105],pre[260],n,m,p,ans,now=0;
void solve()
{
ans=0x3f3f3f3f;
memset(dp,0x3f,sizeof(dp));
dp[0][0][0][8]=0;
for(int i=1;i<=n;i++)
{
int ni=(i&1),lst=(ni^1);
memset(dp[ni],0x3f,sizeof(dp[ni]));
for(int j=0;j<=m;j++)
{
for(int k=0;k<=p;k++)
{
for(int l=0;l<=8;l++)
{
if(dp[lst][j][k][l]>=(0x3f3f3f3f/2))continue;
dp[ni][j][(k|(1<<a[i]))][a[i]]=min(dp[ni][j][(k|(1<<a[i]))][a[i]],dp[lst][j][k][l]+(a[i]!=l));
dp[ni][j+1][k][l]=min(dp[ni][j+1][k][l],dp[lst][j][k][l]);
}
}
}
}
for(int i=0;i<=m;i++)
{
for(int j=0;j<=p;j++)
{
for(int k=0;k<=8;k++)
{
ans=min(ans,dp[(n&1)][i][j][k]+pre[(j^p)&p]);
}
}
}
printf("Case %d: %d\n\n",now,ans);
}
int main()
{
for(int i=0;i<(1<<8);i++)
{
for(int j=0;j<8;j++)
{
pre[i]+=((i>>j)&1);
}
}
while(1)
{
now++;
scanf("%d %d",&n,&m);
if(n==0&&m==0)break;
p=0;
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
a[i]-=25;
p=(p|(1<<a[i]));
}
solve();
}
return 0;
}

Luogu P1777 帮助 题解 [ 紫 ] [ 线性 dp ] [ 状压 dp ]的更多相关文章

  1. 【BZOJ】1076 [SCOI2008]奖励关 期望DP+状压DP

    [题意]n种宝物,k关游戏,每关游戏给出一种宝物,可捡可不捡.每种宝物有一个价值(有负数).每个宝物有前提宝物列表,必须在前面的关卡取得列表宝物才能捡起这个宝物,求期望收益.k<=100,n&l ...

  2. 【Luogu】P1896互不侵犯King(状压DP)

    题目链接 真是可恶,被数据范围坑了一把.想要一遍AC的希望破灭了…… 以后大家在做状压DP的时候一定要开long long…… 设f[i][j][k]表示考虑前i行,总共放了j个King,第i行状态为 ...

  3. hdu 4352 "XHXJ's LIS"(数位DP+状压DP+LIS)

    传送门 参考博文: [1]:http://www.voidcn.com/article/p-ehojgauy-ot.html 题解: 将数字num字符串化: 求[L,R]区间最长上升子序列长度为 K ...

  4. 状态压缩dp 状压dp 详解

    说到状压dp,一般和二进制少不了关系(还常和博弈论结合起来考,这个坑我挖了还没填qwq),二进制是个好东西啊,所以二进制的各种运算是前置知识,不了解的话走下面链接进百度百科 https://baike ...

  5. 洛谷 P3343 - [ZJOI2015]地震后的幻想乡(朴素状压 DP/状压 DP+微积分)

    题面传送门 鸽子 tzc 竟然来补题解了,奇迹奇迹( 神仙题 %%%%%%%%%%%% 解法 1: 首先一件很明显的事情是这个最小值可以通过类似 Kruskal 求最小生成树的方法求得.我们将所有边按 ...

  6. CCF 201312-4 有趣的数 (数位DP, 状压DP, 组合数学+暴力枚举, 推公式, 矩阵快速幂)

    问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, 2, 3,且这四个数字都出现过至少一次. 2. 所有的0都出现在所有的1之前,而所有的2都出现在所有的3之前. 3. 最高 ...

  7. [转]状态压缩dp(状压dp)

    状态压缩动态规划(简称状压dp)是另一类非常典型的动态规划,通常使用在NP问题的小规模求解中,虽然是指数级别的复杂度,但速度比搜索快,其思想非常值得借鉴. 为了更好的理解状压dp,首先介绍位运算相关的 ...

  8. 51nod 1673 树有几多愁(链表维护树形DP+状压DP)

    题意 lyk有一棵树,它想给这棵树重标号. 重标号后,这棵树的所有叶子节点的值为它到根的路径上的编号最小的点的编号. 这棵树的烦恼值为所有叶子节点的值的乘积. lyk想让这棵树的烦恼值最大,你只需输出 ...

  9. BZOJ3836 [Poi2014]Tourism 【树形dp +状压dp】

    题目链接 BZOJ3836 题解 显然这是个\(NP\)完全问题,此题的解决全仗任意两点间不存在节点数超过10的简单路径的性质 这意味着什么呢? \(dfs\)树深度不超过\(10\) \(10\)很 ...

  10. bzoj4455 & loj2091 [Zjoi2016]小星星 容斥原理+树形DP(+状压DP?)

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4455 https://loj.ac/problem/2091 题解 很不错的一道题.(不过在当 ...

随机推荐

  1. golang配置读取值viper

    viper简介 Viper是Go应用程序的完整配置解决方案,包括12-Factor应用程序.它旨在在应用程序中工作,并且可以处理所有类型的配置需求和格式.它支持: 设置默认值 从JSON.TOML.Y ...

  2. redis6.0安装与使用

    [Linux] 源码安装: 下载安装 Cd /usr/local/src/ wget https://download.redis.io/releases/redis-6.0.9.tar.gz $ t ...

  3. The 2023 ICPC Asia Hong Kong Regional Programming Contest

    The 2023 ICPC Asia Hong Kong Regional Programming Contest A. TreeScript 给你一个根,让你构造一棵树,每个节点被创造的时候必须知道 ...

  4. NFS服务搭建过程

    NFS服务 [1].nfs配置 作用: 解决数据一致性问题 NFS服务程序的配置文件为/etc/exports,需要严格按照共享目录的路径 允许访问的NFS客户端(共享权限参数)格式书写,定义要共享的 ...

  5. django数据库反向迁移

    目录 django数据库反向迁移 步骤一:连接MySQL 方式一:使用pymysql连接 方式二:使用mysqlclient连接 步骤二:迁移数据库 正向迁移(通过类创建表) 反向迁移(通过表创建类) ...

  6. C#中定义类时关于CLSCompliant属性的声明

    今天在做code analysis时,遇到了这个提示 Warning 1 CA1014 : Microsoft.Design : Mark 'Demo.exe' with CLSCompliant(t ...

  7. linux服务器下 conda 配置清华源

    安装miniconda 下载安装脚本 wget https://mirrors.tuna.tsinghua.edu.cn/anaconda/miniconda/Miniconda3-latest-Li ...

  8. python SQLAlchemy ORM——从零开始学习 01 安装库

    01基础库 1-1安装 依赖库:sqlalchemy pip install sqlalchemy #直接安装即可 1-2导入使用 这里讲解思路[个人的理解],具体写其实就是这个框架: 导入必要的接口 ...

  9. Mac_工具使用汇总

      Mac安装低版本的Xcode后会出现各种问题,现汇总如下: 1. python3: error: unable to find utility "python3", not a ...

  10. mac_使用Charles抓取Firefox 链接

    1. 首先在Charles 中导出证书,操作为:Help选项 --> SSL Proxying --> 选择第二项 Install Charles Root Certificate 2. ...