题面

luogu

题解

其实就是一颗二叉树

我们假设左儿子小于根,右儿子大于根

考虑树形\(dp\)

\(f[u][i]\)表示以\(u\)为根的子树,\(u\)为第\(i\)小

那么考虑子树合并

其实就是两个序列的合并

如果是左子树

枚举\(j\)为子树内有多少个数小于其根

那么以\(i\)为根的子树一定至少有\(j\)个

那么我们换一下枚举的东西

改成枚举有多少个数小于\(u\)

剩下的问题就是分配权值的问题了

组合数计算一下(具体看代码注释)

Code

#include<bits/stdc++.h>
using namespace std;
const int N = 110, Mod = 1e9 + 7;
int f[N][N], g[N][N], tmp[N], n, siz[N], C[N][N];
char s[N];
struct node {
int to, nxt;
}G[N];
int last[N], gl;
void add(int x, int y) {
G[++gl] = (node) {y, last[x]};
last[x] = gl;
}
void pls(int &x, int y) {
x += y;
if (x >= Mod) x -= Mod;
}
void dfs(int u) {
int ls = u << 1, rs = u << 1 | 1;
if (ls <= n) add(u, ls);
if (rs <= n) add(u, rs);
g[u][1] = f[u][1] = siz[u] = 1;
for (int z = last[u]; z; z = G[z].nxt) {
int v = G[z].to;
dfs(v);
for (int i = 1; i <= siz[u] + siz[v]; i++) tmp[i] = 0;
for (int i = 1; i <= siz[u]; i++)
for (int j = 0; j < siz[v]; j++)//子树v有j个数小于u(不包括v)
if (s[v] == '>')
pls(tmp[i + j + 1], 1ll * f[u][i] * g[v][j + 1] % Mod
* C[i + j][i - 1] % Mod * C[siz[u] + siz[v] - i - j - 1][siz[u] - i] % Mod);//一共有i+j数小于u,分配给i-1个位置权值 , siz[u] + siz[v] - i - j - 1个数大于u
else
pls(tmp[i + j], 1ll * f[u][i] * (g[v][siz[v]] - g[v][j] + Mod) % Mod
* C[i + j - 1][i - 1] % Mod * C[siz[u] + siz[v] - i - j][siz[u] - i] % Mod);
siz[u] += siz[v];
for (int i = 1; i <= siz[u]; i++) f[u][i] = tmp[i], g[u][i] = (g[u][i - 1] + f[u][i]) % Mod;
}
return ;
} int main() {
scanf("%d%s", &n, s + 2);
for (int i = 0; i <= n; i++) C[i][i] = C[i][0] = 1;
for (int i = 2; i <= n; i++)
for (int j = 0; j < i; j++)
C[i][j] = (C[i - 1][j - 1] + C[i - 1][j]) % Mod;
dfs(1);
printf("%d\n", g[1][n]);
return 0;
}

洛谷 P3757 [CQOI2017]老C的键盘的更多相关文章

  1. [bzoj4824][洛谷P3757][Cqoi2017]老C的键盘

    Description 老 C 是个程序员. 作为一个优秀的程序员,老 C 拥有一个别具一格的键盘,据说这样可以大幅提升写程序的速度,还能让写出来的程序 在某种神奇力量的驱使之下跑得非常快.小 Q 也 ...

  2. 洛谷P3757 [CQOI2017]老C的键盘

    传送门 首先可以直接把整个序列建成一个完全二叉树的结构,这个应该都看得出来 然后考虑树形dp,以大于为例 设$f[i][j]$表示$i$这个节点在子树中排名第$j$位时的总方案数(因为实际只与相对大小 ...

  3. Luogu P3757 [CQOI2017]老C的键盘

    题目描述 老C的键盘 题解 显然对于每个数 x 都有唯一对应的 \(x/2\) , 然而对于每个数 x 却可以成为 \(x*2\) 和 \(x*2+1\) 的对应数 根据这一特性想到了啥??? 感谢l ...

  4. [bzoj4823][洛谷P3756][Cqoi2017]老C的方块

    Description 老 C 是个程序员. 作为一个懒惰的程序员,老 C 经常在电脑上玩方块游戏消磨时间.游戏被限定在一个由小方格排成的R行C列网格上 ,如果两个小方格有公共的边,就称它们是相邻的, ...

  5. 洛谷$P3756\ [CQOI2017]$老$C$的方块 网络流

    正解:网络流 解题报告: 传送门$QwQ$ 看到不能出现给定的讨厌的图形,简单来说就,特殊边两侧的方格不能同时再连方格. 所以如果出现,就相当于是四种方案?就分别炸四个格子. 然后冷静分析一波之后发现 ...

  6. [CQOI2017]老C的键盘

    [CQOI2017]老C的键盘 题目描述 额,网上题解好像都是用的一大堆组合数,然而我懒得推公式. 设\(f[i][j]\)表示以\(i\)为根,且\(i\)的权值为\(j\)的方案数. 转移: \[ ...

  7. [BZOJ4824][Cqoi2017]老C的键盘 树形dp+组合数

    4824: [Cqoi2017]老C的键盘 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 218  Solved: 171[Submit][Statu ...

  8. [BZOJ4824][CQOI2017]老C的键盘(树形DP)

    4824: [Cqoi2017]老C的键盘 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 193  Solved: 149[Submit][Statu ...

  9. bzoj 4824: [Cqoi2017]老C的键盘

    Description 老 C 是个程序员.     作为一个优秀的程序员,老 C 拥有一个别具一格的键盘,据说这样可以大幅提升写程序的速度,还能让写出来的程序 在某种神奇力量的驱使之下跑得非常快.小 ...

随机推荐

  1. Python爬虫利器六之PyQuery的用法

    前言 你是否觉得 XPath 的用法多少有点晦涩难记呢? 你是否觉得 BeautifulSoup 的语法多少有些悭吝难懂呢? 你是否甚至还在苦苦研究正则表达式却因为少些了一个点而抓狂呢? 你是否已经有 ...

  2. redhat6.7在线安装postgresql9

    原文:http://wandejun1012.iteye.com/blog/2015777 1.安装postgresql9.0 yum 仓库 rpm -i http://yum.postgresql. ...

  3. linux每天一小步---head命令详解

    1 命令功能      head命令用来查看文件的前多少行或多少字节的内容(默认显示10行) 2 命令语法 head  [选项参数]  [文件名] 3 命令参数 -q  显示多个文件的内容时不显示文件 ...

  4. 团体程序设计天梯赛L2-023 图着色问题 2017-04-17 09:28 269人阅读 评论(0) 收藏

    L2-023. 图着色问题 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 图着色问题是一个著名的NP完全问题.给定无向图 G ...

  5. Internal error(U783)

    今天打开代码时一个单元文件报这个错误Internal error(U783),不知道什么原因,然后多次关闭打开后,又没报这个错误了,记录下 http://www.aiuxian.com/article ...

  6. Android-Camera+SurfaceView

    Camera相机是属于硬件,每台设备的Camera硬件配置的参数都是不一样的,Camera通常是用来拍照,扫描二维码等等 AndroidManifest.xml配置Camera需要的权限: <! ...

  7. shell脚本修改文件

    https://blog.csdn.net/qq_37674858/article/details/80066264 2.2 使用sed命令对文件中的字符替换 例如:将aaaa字符串修改为bbbb [ ...

  8. win10 数字许可证激活被 KMS激活覆盖

    打开cmd(管理员身份),依次执行以下命令: slmgr/upk slmgr/ckms slmgr/rearm 重启设备后联网登录Microsoft账号,转设置-激活-疑难解答,windows会找到与 ...

  9. sql游标循环结果集

    我们知道游标是一种对结果集操作的神器,使用游标,可以很方便的循环结果集,并对结果集进行数据处理. 1.建表 CREATE TABLE [dbo].[Student]( ,) NOT NULL, ) N ...

  10. C语言的第零次作业

    C语言--第0次作业 Q1:对于网络专业的了解 一开始我对网络工程这个专业并不是很了解,在报志愿之前,我完全没想过自己会进这个专业,但是经过了一个暑假的时间,我慢慢地开始了解这个学科,并开始对这个专业 ...