*XXXIV. BZOJ3971 [WF2013]Матрёшка

摘自 DP 做题记录 II 例题 XXXIV.

仍然是神仙区间 DP。

直接设状态 \(f_{i,j}\) 表示区间 \([i,j]\) 的答案不太方便,考虑最终答案一定由若干段 \(1\sim m\) 的套娃合并在一起,所以我们设 \(f_{i,j}\) 表示把 \([i,j]\) 合并成一个套娃的最小代价并设 \(g_i\) 表示把长度 \(i\) 的前缀合并成若干个合法套娃的最小代价,则答案为 \(g_n\)。

考虑怎么算 \(f_{l,r}\):首先 \(l,r\) 不能有相同大小的套娃,记为 \(\mathrm{diff}(l,r)\)。然后枚举断点 \(k\),注意到 \([l,k]\) 所有大于 \(\min [k+1,r]\) 的套娃需要被拆开,以及 \([k+1,r]\) 所有大于 \(\min[l,k]\) 的套娃需要被拆开,这个可以二维前缀和预处理 \(s_{l,V}\) 表示 \(1\sim l\) 有多少个大小在 \(1\sim V\) 的套娃并 \(\mathcal{O}(1)\) 计算。记 \(\mathrm{merge}(l,k,r)\) 表示合并 \([l,k]\) 和 \([k+1,r]\) 的代价,则

\[f_{l,r}=\begin{cases}\min_{k=l}^{r-1}f_{l,k}+f_{k+1,r}+\mathrm{merge}(l,k,r)& \mathrm{diff}(l,r)\\\infty&\mathrm{otherwise}\end{cases}
\]

\(g\) 的转移是 trivial 的:

\[g_i=\min_{j=0}^{i-1}\begin{cases}g_j+f_{j+1,i} & \mathrm{mex}(j+1,i)=i-j+1\\\infty&\mathrm{otherwise}\end{cases}
\]

若 \(g_n=\infty\) 则输出 impossible,时间复杂度 \(\mathcal{O}(n^3)\)。

 const int N = 500 + 5;
const int inf = 1e8; int n, a[N], f[N], g[N][N], s[N][N], mi[N][N], mex[N][N], ck[N][N];
int cal(int l, int r, int x1, int x2) {
return s[r][x2] - s[l - 1][x2] - s[r][x1 - 1] + s[l - 1][x1 - 1];
}
void cmex(int l, int r) {
static int buc[N]; mem(buc, 0, N), mex[l][r] = 1;
for(int i = l; i <= r; i++) buc[a[i]] = 1;
while(buc[mex[l][r]]) mex[l][r]++;
}
void csam(int l, int r) {
static int buc[N]; mem(buc, 0, N);
for(int i = l; i <= r; i++)
ck[l][r] |= buc[a[i]], buc[a[i]] = 1;
}
int mer(int l, int k, int r) {
assert(l <= k && k < r && !ck[l][r]);
int m1 = mi[l][k], m2 = mi[k + 1][r];
return cal(l, k, m2, N - 1) + cal(k + 1, r, m1, N - 1);
}
int main() {
cin >> n, mem(mi, 31, N), mem(g, 31, N), mem(f, 31, N), f[0] = 0;
for(int i = 1; i <= n; i++) s[i][a[i] = read()]++, g[i][i] = 0;
for(int i = 1; i <= n; i++)
for(int j = 1; j < N; j++)
s[i][j] += s[i][j - 1] + s[i - 1][j] - s[i - 1][j - 1];
for(int i = 1; i <= n; i++)
for(int j = i; j <= n; j++)
cmex(i, j), csam(i, j), mi[i][j] = min(mi[i][j - 1], a[j]);
for(int len = 2; len <= n; len++)
for(int l = 1, r = len; r <= n; l++, r++)
if(!ck[l][r]) for(int k = l; k < r; k++)
g[l][r] = min(g[l][r], g[l][k] + g[k + 1][r] + mer(l, k, r));
for(int i = 1; i <= n; i++)
for(int j = 0; j < i; j++)
if(mex[j + 1][i] == i - j + 1)
f[i] = min(f[i], f[j] + g[j + 1][i]);
if(f[n] >= inf) puts("Impossible");
else cout << f[n] << endl;
return 0;
}

BZOJ3971 [WF2013]Матрёшка的更多相关文章

  1. 【BZOJ】3971 [WF2013]Матрёшка

    [算法]区间DP [题解] 参考写法:BZOJ 3971 Матрёшка 解题报告 第二个DP可以预处理mex优化到O(nM+n2),不过我懒…… 第一个DP有另一种写法:不预处理,在一个n2取出来 ...

  2. ACM - ICPC World Finals 2013 H Матрёшка

    原题下载:http://icpc.baylor.edu/download/worldfinals/problems/icpc2013.pdf 题目翻译: 问题描述 俄罗斯套娃是一些从外到里大小递减的传 ...

  3. BZOJ 3971 Матрёшка 解题报告

    很自然想到区间 DP. 设 $Dp[i][j]$ 表示把区间 $[i, j]$ 内的套娃合并成一个所需要的代价,那么有: $Dp[i][i] = 0$ $Dp[i][j] = min\{Dp[i][k ...

  4. 区间dp提升复习

    区间\(dp\)提升复习 不得不说这波题真的不简单... 技巧总结: 1.有时候转移可以利用背包累和 2.如果遇到类似区间添加限制的题可以直接把限制扔在区间上,每次只考虑\([l,r]\)被\([i, ...

  5. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  6. hibernate 中文文档

    转载:http://blog.csdn.net/kevon_sun/article/details/42850387 Hibernate Annotations 参考文档 3.2.0 CR1 目录 前 ...

  7. ACM International Collegiate Programming Contest World Finals 2013

    ACM International Collegiate Programming Contest World Finals 2013 A - Self-Assembly 题目描述:给出\(n\)个正方 ...

  8. BZOJ_3969_[WF2013]Low Power_二分答案

    BZOJ_3969_[WF2013]Low Power_二分答案 Description 有n个机器,每个机器有2个芯片,每个芯片可以放k个电池. 每个芯片能量是k个电池的能量的最小值. 两个芯片的能 ...

  9. bzoj 3969: [WF2013]Low Power 二分

    3969: [WF2013]Low Power Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnli ...

随机推荐

  1. Java:内部类小记

    Java:内部类小记 对 Java 中的 内部类,做一个微不足道的小小小小记 首先:内部类是指在一个外部类的内部再定义一个类.内部类作为外部类的一个成员,并且依附于外部类而存在的. 成员内部类 成员内 ...

  2. 权限管理RBAC模型概述

    一.什么是RBAC模型 RBAC模型(Role-Based Access Control:基于角色的访问控制)模型是比较早期提出的权限实现模型,在多用户计算机时期该思想即被提出,其中以美国George ...

  3. [no_code]团队任务拆解Alpha

    项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 团队任务拆解 我们在这个课程的目标是 远程协同工作,采用最新技术开发软件 这个作业在哪个具体方面帮 ...

  4. 热身训练1 ping ping ping

    点此进入 题意: 一棵树,n+1 个节点,以0号节点为根,给出端点(a,b),节点a到节点b的路径上,至少有一个点是"坏掉的",求"坏掉的点"最少 分析: St ...

  5. 零基础学习C语言入门必备知识

    今天跟大家一起从零学C语言: 1. C语言简介 1.1 C语言发展史 C语言是一种广泛使用的面向过程的计算机程序设计语言,既适合于系统程序设计,又适合于应用程序设计.C语言的发展历程大致如图1-1所示 ...

  6. 决策树 机器学习,西瓜书p80 表4.2 使用信息增益生成决策树及后剪枝

    使用信息增益构造决策树,完成后剪枝 目录 使用信息增益构造决策树,完成后剪枝 1 构造决策树 1 根结点的选择 色泽 信息增益 根蒂 信息增益 敲声 信息增益 纹理 信息增益 脐部 信息增益 触感 信 ...

  7. git commit--fatal: unable to auto-detect email address

    git commit的时候报错 *** Please tell me who you are. Run git config --global user.email "you@example ...

  8. poj 3041 Asteroids(最小点覆盖)

    题意: N*N的矩阵,有K个敌人,坐标分别是(C1,C1),.....,(Rk,Ck). 有一个武器,每发射一次,可消掉某行或某列上的所有的敌人. 问消灭所有敌人最少需要多少发. 思路: 二分建图:左 ...

  9. Typora和PicGo-Core搭配使用

    作用:快速上传图片并获取图片 URL 链接的工具,图片存放到Gitee仓库中,在博客网站发布时不必担心图片转存失败问题 Gitee 创建一个新仓库 生成一个新令牌 生成后只显示一次,请妥善保管 Pic ...

  10. DeWeb 简介

    DeWeb是一个可以直接将Delphi程序快速转换为网页应用的工具! 使用DeWeb, 开发者不需要学习HTML.JavaScript.Java.PHP.ASP.C#等新知识,用Delphi搞定一切. ...