<更新提示>

<第一次更新>


<正文>

count

Description

既然是萌萌哒 visit_world 的比赛,那必然会有一道计数题啦!

考虑一个N个节点的二叉树,它的节点被标上了1-N的编号. 并且,编号为i的节点在二叉树的前序遍历中恰好是第i个出现.

我们定义Ai表示编号为i的点在二叉树的中序遍历中出现的位置.

现在,给出M个限制条件,第i个限制条件给出了ui,vi,表示 Aui<Avi,也即中序遍历中ui在vi之前出现.

你需要计算有多少种不同的带标号二叉树满足上述全部限制条件,答案对\(10^9+7\)取模.

Input Format

第一行一个整数T(1≤T≤5), 表示数据组数.

每组数据第一行为两个整数N,M,意义如题目所述.

接下来M行,每行两个整数ui,vi(1≤ui,vi≤N) , 描述一条限制。

Output Format

对每组数据,输出一行一个整数,表示答案.

Sample Input

3
5 0
3 2
1 2
2 3
3 3
1 2
2 3
3 1

Sample Output

42
1
0

解析

我们知道一个前序遍历和一个中序遍历可以唯一确定一棵二叉树,也就是让我们求前序遍历在满足\(m\)个限定要求下可以对应多少个中序遍历。

考虑区间\(dp\),\(f[l][r]\)代表前序遍历的区间为\([l,r]\),\(l\)为根节点的子树中对应的方案数。

如果没有限制,直接考虑划分子树的方式划分区间,转移累加方案数即可。有限制时,也就是有些转移不能执行了,我们可以把限制打在一个二维数组里,求一下二维前缀和实现矩阵求和。这样转移时的限制查询就可以变成某个矩阵的求和了,若有值就说明存在若干限制,不能转移。

\(Code:\)

#include <bits/stdc++.h>
using namespace std;
const int N = 420 , Mod = 1e9+7;
int n,m,s[N][N];
long long f[N][N];
inline void input(void)
{
scanf("%d%d",&n,&m);
for (int i=1;i<=m;i++)
{
int x,y;
scanf("%d%d",&x,&y);
s[x][y] ++;
}
}
inline int calc(int x1,int y1,int x2,int y2) { return s[x2][y2] - s[x1-1][y2] - s[x2][y1-1] + s[x1-1][y1-1]; }
inline void init(void)
{
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
s[i][j] += s[i][j-1];
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
s[i][j] += s[i-1][j];
}
inline void add(long long &a,long long b) { a += b; if ( a >= Mod ) a -= Mod; }
inline void dp(void)
{
for (int i=1;i<=n;i++) f[i][i] = 1;
for (int len=2;len<=n;len++)
for (int l=1,r;(r=l+len-1)<=n;l++)
{
if ( calc( l , l+1 , l , r ) == 0 )
add( f[l][r] , f[l+1][r] );
if ( calc( l+1 , l , r , l ) == 0 )
add( f[l][r] , f[l+1][r] );
for (int k=l+1;k<=r-1;k++)
if ( calc( l , l+1 , l , k ) == 0 && calc( k+1 , l , r , k ) == 0 )
add( f[l][r] , 1LL * f[l+1][k] * f[k+1][r] % Mod );
}
}
int main(void)
{
freopen("input.in","r",stdin);
freopen("output.out","w",stdout);
int T;
scanf("%d",&T);
while ( T --> 0 )
{
memset( f , 0 , sizeof f );
memset( s , 0 , sizeof s );
input();
init();
dp();
printf("%lld\n",f[1][n]);
}
return 0;
}

<后记>

『count 区间dp』的更多相关文章

  1. 『Blocks 区间dp』

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

  2. 『金字塔 区间dp』

    金字塔 Description 虽然探索金字塔是极其老套的剧情,但是这一队 探险家还是到了某金字塔脚下.经过多年的研究,科 学家对这座金字塔的内部结构已经有所了解.首先, 金字塔由若干房间组成,房间之 ...

  3. 『大 树形dp』

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

  4. 『kamp 树形dp』

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

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

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

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

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

  7. 「学习笔记」动态规划 I『初识DP』

    写在前面 注意:此文章仅供参考,如发现有误请及时告知. 更新日期:2018/3/16,2018/12/03 动态规划介绍 动态规划,简称DP(Dynamic Programming) 简介1 简介2 ...

  8. P1040 加分二叉树 区间dp

    题目描述 设一个nn个节点的二叉树tree的中序遍历为(1,2,3,…,n1,2,3,…,n),其中数字1,2,3,…,n1,2,3,…,n为节点编号.每个节点都有一个分数(均为正整数),记第ii个节 ...

  9. 『Python基础-4』字符串

    # 『Python基础-4』字符串 目录 1.什么是字符串 2.修改字符串 2.1 修改字符串大小 2.2 合并(拼接)字符串 2.3 使用乘号'*'来实现字符串的叠加效果. 2.4 在字符串中添加空 ...

随机推荐

  1. 关于Qt 静态成员函数调用信号

    class globalCalcThread; extern globalCalcThread *g_calcThread; class globalCalcThread : public QThre ...

  2. JavaScript调用百度地图

    在网站开发过程中,经常会调用到地图,百度地图提供Web开发.Android开发.iOS开发API及SDK,百度地图JavaScript API可帮助您在网站中构建功能丰富.交互性强的地图应用,本篇博客 ...

  3. nodejs块级作用域

    现在让我们了解3个关键字var.let.const,的特性和使用方法. var JavaScript中,我们通常说的作用域是函数作用域,使用var声明的变量,无论是在代码的哪个地方声明的,都会提升到当 ...

  4. 奖金高达150万元的NEST即将上线,速来报名

    表哥.表姐们快粗来~~~分享一个劲爆消息: 年度奖金总额高达150万元的众测平台(NEST)已于2019年6月10日启动全球报名,6月26号开始首批线上众测,欢迎精英白帽们前来挑战! 更多详情请认真阅 ...

  5. ios官方demo

    http://developer.apple.com/iphone/library/samplecode/Reachability/Reachability.ziphttp://developer.a ...

  6. 【MongoDB详细使用教程】三、高级查询

    目录 1.使用比较运算符查询 2.使用关键字查询 2.1.in/not in 关键字 2.2.size 关键字 2.3.exists 关键字 2.4.or 关键字 3.模糊查询 4.查询结果排序 5. ...

  7. [TCP/IP] TCP的重发机制是怎么实现的

    1)滑动窗口机制,确立收发的边界,能让发送方知道已经发送了多少(已确认).尚未确认的字节数.尚待发送的字节数:让接收方知道(已经确认收到的字节数) 2) 超时重传,tcp每发送一个报文段,就设置一次计 ...

  8. python简单日志处理

    简单日志处理 import datetime import re logfile='''58.61.164.141 - - [22/Feb/2010:09:51:46 +0800] "GET ...

  9. Unity检视面板的继承方法研究 (二)

    之前做了普通对象的可继承的检视面板类, 现在想要实现对Unity自带的检视面板的继承的话, 要怎样写呢? 万变不离其宗,  仍然是围绕UnityEditor.Editor.CreateEditor 这 ...

  10. Rust中的模块及私有性控制

    好像没有其它语言的private, protected关键字,应了一个public关键字. mod plant { pub struct Vegetable { pub name: String, _ ...