bzoj 4824: [Cqoi2017]老C的键盘
Description
Input
Output
Sample Input
Sample Output
共5个按键,第1个按键比第2个按键矮,第1个按键比第3个按键高,第2个按键比第4个
按键高,第2个按键比第5个按键矮。
这5个按键的高度排列可以是 2,4,1,3,5 , 3,4,1,2,5 , 3,4,2,1,5 。
HINT
Source
之前看到这个题的时候毫无想法,现在看起来和实验比较的做法差不多(这个题好像有原题,bzoj 2111 和 bzoj 3167)
woc这原来都是一个题,但是这题我的做法和实验比较的做法差不多;
首先题目给了一棵完全二叉树,然后给了父亲和儿子的关系,那么我们设dp[i][j],表示i的子树内,i的排名为j的方案数;
然后做法流程和实验比较类似,合并(x,i),(y,j)时首先分情况枚举合并后x的rank为k;
1.x>y;
那么k从i枚举到i+j-1,然后就相当于这样一个问题:
前半段有k-1个盒子,i-1个红球,k-1-(i-1)个蓝球,后半段有size[x]+size[y]-k个盒子,有size[x]-i个红球,...个蓝球,
红蓝球都有顺序;
然后问每个盒子都填了一个球,而且红蓝球的内部顺序不变的方案数:
那么转移就是:
2.x<y
k就是从i+j,枚举到i+size[y],然后转移是一模一样的;
然后具体实现方法和实验比较一样。。。
//MADE BY QT666
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
typedef long long ll;
const int N=1050;
const int Mod=1e9+7;
ll c[N][N],size[N],dp[N][N],g[N],head[N],to[N],nxt[N],type[N],cnt,n;
char s[N];
void lnk(int x,int y,int z){
to[++cnt]=y,nxt[cnt]=head[x],type[cnt]=z,head[x]=cnt;
}
void dfs(int x){
size[x]=1;
for(int p=head[x];p;p=nxt[p]){
int y=to[p],flg=type[p];dfs(y);
if(flg==1){
if(size[x]==1){
for(int i=1;i<=size[y];i++){
for(int j=1;j<=i;j++) (dp[x][j]+=dp[y][i])%=Mod;
}
size[x]+=size[y];
for(int i=1;i<=size[x];i++) g[i]=dp[x][i];
}
else{
int tot=size[x]+size[y];
for(int i=1;i<=size[x];i++){
for(int j=1;j<=size[y];j++){
for(int k=i;k<=i+j-1;k++){
(g[k]+=dp[x][i]*dp[y][j]%Mod*c[k-1][i-1]%Mod*c[tot-k][size[x]-i]%Mod)%=Mod;
}
}
}
size[x]+=size[y];
for(int i=1;i<=size[x];i++) dp[x][i]=g[i];
}
}
else {
if(size[x]==1){
for(int i=1;i<=size[y];i++){
for(int j=i;j<=size[y];j++) (dp[x][j+1]+=dp[y][i])%=Mod;
}
size[x]+=size[y];
for(int i=1;i<=size[x];i++) g[i]=dp[x][i];
}
else{
int tot=size[x]+size[y];
for(int i=1;i<=size[x];i++){
for(int j=1;j<=size[y];j++){
for(int k=i+j;k<=i+size[y];k++){
(g[k]+=dp[x][i]*dp[y][j]%Mod*c[k-1][i-1]%Mod*c[tot-k][size[x]-i]%Mod)%=Mod;
}
}
}
size[x]+=size[y];
for(int i=1;i<=size[x];i++) dp[x][i]=g[i];
}
}
}
if(size[x]==1) dp[x][1]=1;
memset(g,0,sizeof(g));
}
int main(){
scanf("%lld",&n);scanf("%s",s+1);
for(int i=2;i<=n;i++){
if(s[i-1]=='<') lnk(i/2,i,1);
if(s[i-1]=='>') lnk(i/2,i,2);
}
for(int i=0;i<=n;++i) c[i][0]=1;
for(int i=1;i<=n;++i)
for(int j=1;j<=i;++j){
c[i][j]=(c[i-1][j-1]+c[i-1][j])%Mod;
}
dfs(1);ll ans=0;
for(int i=1;i<=size[1];i++) (ans+=dp[1][i])%=Mod;
printf("%lld\n",ans);
return 0;
}
bzoj 4824: [Cqoi2017]老C的键盘的更多相关文章
- BZOJ 4824 [Cqoi2017]老C的键盘 ——树形DP
每一个限制条件相当于一条有向边, 忽略边的方向,就成了一道裸的树形DP题 同BZOJ3167 唯一的区别就是这个$O(n^3)$能过 #include <map> #include < ...
- bzoj 4824: [Cqoi2017]老C的键盘【树形dp】
参考:https://www.cnblogs.com/FallDream/p/bzoj4824.html 画一画就会发现关系形成了一棵二叉树(其实看到n-1就能想到 然后dp,设f[i][j]为点i在 ...
- [BZOJ4824][Cqoi2017]老C的键盘 树形dp+组合数
4824: [Cqoi2017]老C的键盘 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 218 Solved: 171[Submit][Statu ...
- [BZOJ4824][CQOI2017]老C的键盘(树形DP)
4824: [Cqoi2017]老C的键盘 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 193 Solved: 149[Submit][Statu ...
- [CQOI2017]老C的键盘
[CQOI2017]老C的键盘 题目描述 额,网上题解好像都是用的一大堆组合数,然而我懒得推公式. 设\(f[i][j]\)表示以\(i\)为根,且\(i\)的权值为\(j\)的方案数. 转移: \[ ...
- bzoj 4822: [Cqoi2017]老C的任务
4822: [Cqoi2017]老C的任务 练手速... #include <iostream> #include <cstdio> #include <cstring& ...
- bzoj 4823: [Cqoi2017]老C的方块 [最小割]
4823: [Cqoi2017]老C的方块 题意: 鬼畜方块游戏不解释... 有些特殊边,有些四个方块组成的图形,方块有代价,删掉一些方块使得没有图形,最小化代价. 比较明显的最小割,一个图形中必须删 ...
- [bzoj4824][Cqoi2017]老C的键盘
来自FallDream的博客,未经允许,请勿转载,谢谢. 老 C 是个程序员. 作为一个优秀的程序员,老 C 拥有一个别具一格的键盘,据说这样可以大幅提升写程序的速度,还能让写出来的程序在某种 ...
- [bzoj4824][洛谷P3757][Cqoi2017]老C的键盘
Description 老 C 是个程序员. 作为一个优秀的程序员,老 C 拥有一个别具一格的键盘,据说这样可以大幅提升写程序的速度,还能让写出来的程序 在某种神奇力量的驱使之下跑得非常快.小 Q 也 ...
随机推荐
- 《java.util.concurrent 包源码阅读》27 Phaser 第一部分
Phaser是JDK7新添加的线程同步辅助类,作用同CyclicBarrier,CountDownLatch类似,但是使用起来更加灵活: 1. Parties是动态的. 2. Phaser支持树状结构 ...
- TFboy养成记 MNIST Classification (主要是如何计算accuracy)
参考:莫烦. 主要是运用的MLP.另外这里用到的是批训练: 这个代码很简单,跟上次的基本没有什么区别. 这里的lossfunction用到的是是交叉熵cross_entropy.可能网上很多形式跟这里 ...
- 个人笔记之json实现模糊查询
1:首先创建一个项目如:(说明:此项目是在eclipse创建的) 2.在创建相对应的包如: 3.创建写好相对应的配置文件如: applicationContext.xml具体内容如下: <?xm ...
- iOS 中 .a 和 .framework 静态库的创建与 .bundle 资源包的使用
iOS 中 .a 和 .framework 静态库的创建与 .bundle 资源包的使用 前言 开发中经常使用三方库去实现某特定功能,而这些三方库通常又分为开源库和闭源库.开源库可以直接拿到源码,和自 ...
- debounce去弹跳
通过返回闭包,来共用timer定时器,通过定时器的清除和设置来实现每次触发后重新计时. /** * * @param fn {Function} 实际要执行的函数 * @param delay {Nu ...
- angular中复制文字到剪切板
function copyToClipboard(oElement, value) { var aux = document.createElement("input"); if ...
- codeforces #447 894A QAQ 894B Ralph And His Magic Field 894C Marco and GCD Sequence
A.QAQ 题目大意:从给定的字符串中找出QAQ的个数,三个字母的位置可以不连续 思路:暴力求解,先找到A的位置,往前扫,往后扫寻找Q的个数q1,q2,然 后相乘得到q1*q2,这就是这个A能够找到的 ...
- Aurora Player 开源啦~~~
上一年做了很久的项目,是一个完整版的视频播放器,强大.美观!!! 现在转投UWP了,决定开源这个项目. 在你下载本项目之前,请仔细阅读每一行字,以免以后引起不必要的法律纠纷. 本项目最终解释权归本人所 ...
- Windows 服务多语言化时读取配置文件失败的问题。
在Installer中,按一般读取配置文件的方法(ConfigurationManager.AppSettings["CultureName"])读取不到内容. 可以这样读取: v ...
- THINKPHP增删改查--(改)
1.CURD 控制器?>namespace Home\Controller;use Think\Controller;class CurdController extends Controlle ...