<更新提示>

<第一次更新>


<正文>

金字塔

Description

虽然探索金字塔是极其老套的剧情,但是这一队 探险家还是到了某金字塔脚下。经过多年的研究,科 学家对这座金字塔的内部结构已经有所了解。首先, 金字塔由若干房间组成,房间之间连有通道。如果把 房间看做节点,通道看做边的话,整个金字塔呈现一 个有根树结构,节点的子树之间有序,金字塔有唯一 的一个入口通向树根。并且,每个房间的墙壁都涂有 若干种颜色的一种。

探险队员打算进一步了解金字塔的结构,为此,他们使用了一种特殊设计的机器人。这 种机器人会从入口进入金字塔,之后对金字塔进行深度优先遍历。机器人每进入一个房间(无 论是第一次进入还是返回),都会记录这个房间的颜色。最后,机器人会从入口退出金字塔。 显然,机器人会访问每个房间至少一次,并且穿越每条通道恰好两次(两个方向各一次), 然后,机器人会得到一个颜色序列。但是,探险队员发现这个颜色序列并不能唯一确定金字 塔的结构。现在他们想请你帮助他们计算,对于一个给定的颜色序列,有多少种可能的结构 会得到这个序列。由于结果可能会非常大,你只需要输出答案对10^9 取模之后的值。

Input Format

输入文件包含一行,含有一个字符串,表示机器人得到的颜色序列。

Output Format

输出一个整数表示答案。

Sample Input

ABABABA

Sample Output

5

解析

在树形结构中,一棵子树可以对应一个序列区间上的区间,所以不难想到可以使用区间\(dp\)来计数,状态即为:\(f[l][r]\)代表字符串中\([l,r]\)这一段对应的方案数。

对于区间\([l,r]\)所对应的子树,我们考虑如何进行划分。显然,对应的一个根节点棵可能有很多个子节点,如果枚举每一个子树的划分点就会超时,换一种思路,我们枚举区间\([l,r]\)第一棵子树的位置,假设有划分点\(mid\),且\(s[l]=s[mid]\),则\([l+1,mid-1]\)就恰好可以对应一个子树,\(s[l]\)和\(s[mid]\)就是进出时产生的字符。而剩余部分\([mid,r]\)也就刚好对应了一个子问题,直接将方案数累加即可。

\(Code:\)

#include<bits/stdc++.h>
using namespace std;
const int N = 320 , Mod = 1e9;
int n; char a[N];
long long f[N][N];
inline void input(void)
{
scanf("%s",a+1);
n = strlen( a+1 );
}
inline void dp(void)
{
memset( f , 0x00 , sizeof f );
for (int i=1;i<=n;i++) f[i][i] = 1;
for (int len=3;len<=n;len++)
{
for (int l=1;l+len-1<=n;l++)
{
int r = l+len-1;
if ( a[l] != a[r] ) continue;
f[l][r] = f[l+1][r-1];
for (int mid=l+2;mid<=r-2;mid++)
if ( a[l] == a[mid] )
f[l][r] = ( f[l][r] + f[l+1][mid-1] * f[mid][r] % Mod ) % Mod;
}
}
}
int main(void)
{
input();
dp();
printf("%lld\n",f[1][n]);
return 0;
}

<后记>

『金字塔 区间dp』的更多相关文章

  1. 『count 区间dp』

    count Description 既然是萌萌哒 visit_world 的比赛,那必然会有一道计数题啦! 考虑一个N个节点的二叉树,它的节点被标上了1-N的编号. 并且,编号为i的节点在二叉树的前序 ...

  2. 『Blocks 区间dp』

    Blocks Description Some of you may have played a game called 'Blocks'. There are n blocks in a row, ...

  3. $CH5302$ 金字塔 区间$DP$/计数类$DP$

    CH Sol f[l][r]表示l到r这段区间对应的金字塔结构种数 发现是f[l][r]是可以由比它小的区间推出来的 比如已知f[l+1][k],f[k+1][r],不难想到f[l][r]+=f[l+ ...

  4. 【CH5302】金字塔 区间DP

    题目大意:给定一棵树,树上点有标记,给定一棵树的\(dfs\)序标记序列,求有多少种可能的子树形态.(子树之间有序) 这是一道区间计数类DP,涉及到树的\(dfs\)序. 这道题区间的划分点 \(k\ ...

  5. 『大 树形dp』

    大 Description 滑稽树上滑稽果,滑稽树下你和我,滑稽树前做游戏,滑稽多又多.树上有 n 个节点,它们构成了一棵树,每个节点都有一个滑稽值. 一个大的连通块是指其中最大滑稽值和最小滑稽值之差 ...

  6. 『kamp 树形dp』

    kamp Description jz 市的云台山是个很美丽的景区,小 x 暑期到云台山打工,他的任务是开景区的大巴. 云台山景区有 N 个景点,这 N 个景点由 N-1 条道路连接而成,我们保证这 ...

  7. 『字符合并 区间dp 状压dp』

    字符合并 Description 有一个长度为 n 的 01 串,你可以每次将相邻的 k 个字符合并,得到一个新的字符并获得一定分数.得到的新字符和分数由这 k 个字符确定.你需要求出你能获得的最大分 ...

  8. 『土地征用 Land Acquisition 斜率优化DP』

    斜率优化DP的综合运用,对斜率优化的新理解. 详细介绍见『玩具装箱TOY 斜率优化DP』 土地征用 Land Acquisition(USACO08MAR) Description Farmer Jo ...

  9. CH 5302 金字塔(区间DP)

    CH 5302 金字塔 \(solution:\) 很神奇的一道题目,当时看到还以为是一道字符串求回文子串的题目.但是数据范围很小,而且只知道回文串也不好做.但是我们观察可得,如果是深度搜索便利,那么 ...

随机推荐

  1. <Android Studio> 2.APP开机启动

    开机启动,也就是App随着机器开机而启动,在很多工业场景中是非常常见的. 开机启动的基本原理就是监听系统启动相关的广播,然后启动App. 为了实现开机启动,我人为的分为几个步骤 1.创建broadca ...

  2. 一个很简单的SpringCloud项目,集成Feign、Hystrix

    Feign的功能:这是个消费者,根据服务注册在Eureka的ID去找到该服务,并调用接口Hystrix的功能:熔断器,假如A服务需要调用B服务的/cities接口获取数据,那就在A服务的control ...

  3. Spring项目配置多数据源

    项目中有用到多数据源,并进行动态切换,使用的是阿里的druid.看网上有一篇大致一样的就偷偷懒 import java.sql.SQLFeatureNotSupportedException; imp ...

  4. day 45

    目录 form表单(**************) 参数 action method select标签 下拉框 textarea标签 CSS 注释 css的语法结构 css的三种引入方式 css查找( ...

  5. IDEA Mac 快捷键

    智能提示 ⌘ -> command ⇧ -> shift ⌥ -> option ⬆ -> 上箭头 ⬇ -> 下箭头 ⌃ -> Control 编辑 快捷键 说明 ...

  6. MySQL基础SQL命令---增删改查

    1.表操作: create table tableName (id int(6) not null primary key auto_increatment,name varchar(10) not ...

  7. rollup入门

    作为js程序员,掌握rollup是必要的. 有了webpack后,为什么还要用rollup, 因为webpack不专业,webpack是打包一切. rollup只为打包js而生. rollup通过的五 ...

  8. The 2019 Asia Nanchang First Round Online Programming Contest E. Magic Master

    题目链接:https://nanti.jisuanke.com/t/41352 题目意思还是好理解的,看过的人不多,感觉是被通过量吓到了.其实就是个水题,反向模拟就好了, 用队列模拟,反向模拟,它要放 ...

  9. Python八大算法的实现,插入排序、希尔排序、冒泡排序、快速排序、直接选择排序、堆排序、归并排序、基数排序。

    Python八大算法的实现,插入排序.希尔排序.冒泡排序.快速排序.直接选择排序.堆排序.归并排序.基数排序. 1.插入排序 描述 插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得 ...

  10. java 的守护进程脚本

    #!/bin/sh ] do Tag=`ps -ef|grep 'jar包名称'|grep -v grep|wc -l|awk '{printf $1"\n"}'` ] then ...