1996: [Hnoi2010]chorus 合唱队
链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1996
Description

Input

Output

Sample Input
1701 1702 1703 1704
Sample Output
HINT

题解:还是一个区间动归,可是这道题的问题在于比较难想到怎么去设,我们会发现每次放一个数时我们都会
考虑放在左边还是放在右边,实际上最后数放在左边还是右边的方案数是不同的,所以我们除了枚举区间,还要枚举当前这个数是放在了左边还是放在了右边,先来结合动态转移方程看一看:
if (a[j]>a[i]) f[i][j][1]+=f[i][j-1][0];
if (a[j]>a[j-1]) f[i][j][1]+=f[i][j-1][1];
if (a[i]<a[j]) f[i][j][0]+=f[i+1][j][1];
if (a[i]<a[i+1]) f[i][j][0]+=f[i+1][j][0];
(是不是看着觉得很莫名其妙?别急,解释一下。)我们用f[i][j][0]表示构成区间i~j有多少种可能,且这个区间最后一个被放进的数存在最左边,即i处,同理,f[i][j][1]表示最后一个被放进的数存在最右边,即j处。a数组则用来存储这个队列。
先来看第一个式子
if (a[j]>a[i]) f[i][j][1]+=f[i][j-1][0];这个式子的意思是,我们设当前i~j区间最后一个数放在了最右边即a[j],则上一个区间为f[i][j-1],我们又设上一次区间的最后一个数放在了f[i][j-1]的左边即a[i],那么上一次的方案数即为f[i][j-1][0],我们判断这种方案成立的方法即为如果这次的这个数被放在了最右边,那么它是大于上一次的数,即a[j]需大于a[i],如果大于,那么这种方案就成立,就可以加上这种方案数。如图:

这么左右左右去枚举一下总共有四种可能,这就是为什么上面有四个方程式。
具体看程序吧:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int ans,n,j,a[],f[][][];//我刚开始数组没开对,调了很久,最后一个一定要设为2而不是1;
int main()
{
scanf("%d",&n);
for (int i=;i<=n;i++) scanf("%d",&a[i]);
memset(f,,sizeof(f));
for (int i=;i<=n;i++) f[i][i][]=;//刚开始构成单个的方案数皆为一
for (int len=;len<=n;len++)//枚举长度
for (int i=;i<=n-len+;i++)
//这两句for循环其实等同于
for (int i=n;i>=;i--)
for (int j=i;j<=n;j++)
{
j=i+len-;
if (a[j]>a[i]) f[i][j][]+=f[i][j-][];
if (a[j]>a[j-]) f[i][j][]+=f[i][j-][];
if (a[i]<a[j]) f[i][j][]+=f[i+][j][];
if (a[i]<a[i+]) f[i][j][]+=f[i+][j][];//之前解释过的动态转移方程
f[i][j][]%=;
f[i][j][]%=;//题目要求
}
ans=(f[][n][]+f[][n][])%;//答案是左右之和
printf("%d\n",ans);
return ;
}
(咳咳,我看了半天人家的题解)
1996: [Hnoi2010]chorus 合唱队的更多相关文章
- BZOJ 1996: [Hnoi2010]chorus 合唱队(dp)
简单的dp题..不能更水了.. --------------------------------------------------------------- #include<cstdio&g ...
- 【BZOJ】1996: [Hnoi2010]chorus 合唱队【区间dp】
1996: [Hnoi2010]chorus 合唱队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 2088 Solved: 1371[Submit][ ...
- bzoj 1996: [Hnoi2010]chorus 合唱队
Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Output 8 HINT Source 因为只会在区间的两端进行 ...
- BZOJ 1996: [Hnoi2010]chorus 合唱队(区间dp)
题目: https://www.lydsy.com/JudgeOnline/problem.php?id=1996 题解: 这题刚拿到手的时候一脸懵逼qwq,经过思考与分析(看题解),发现是一道区间d ...
- 1996: [Hnoi2010]chorus 合唱队 - BZOJ
Description Input Output Sample Input41701 1702 1703 1704Sample Output8HINT 水题,区间dp,f[l,r,k]表示区间[l,r ...
- bzoj1196:[Hnoi2010]chorus 合唱队
这数据范围明显的区间dp啊...然而据说二维会wa...那就写三维把... #include<cstdio> #include<cstring> #include<cct ...
- bzoj千题计划211:bzoj1996: [Hnoi2010]chorus 合唱队
http://www.lydsy.com/JudgeOnline/problem.php?id=1996 f[i][j][0/1] 表示已经排出队形中的[i,j],最后一个插入的人在[i,j]的i或j ...
- 【BZOJ1996】[Hnoi2010]chorus 合唱队 区间DP
[BZOJ1996][Hnoi2010]chorus 合唱队 Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Ou ...
- BZOJ1996 [Hnoi2010]chorus 合唱队
很容易想到区间DP 然后发现这个区间只和圆序列的最后一个数有关,而原序列的最后一个数只可能是现在区间的头或者尾 令$f[i][j][0/1]$表示在区间$[i, j]$之间,原序列的最后一个数是当前区 ...
随机推荐
- gulp 学习笔记 (初识)
根据极客学院入门视频整理 一.gulp介绍,主要提到了gulp是基于流式来管理运行的,目前完全搞不懂这一套专业术语. 二.gulp的安装使用. 1.首先需要在全局环境下安装gulp npm insta ...
- WAP端 touch事件触发顺序记录
IOS7.0 safari 滚动滚动条的时候, 最后手指放开 (scroll 总是在 touchend后面,所以要用 setTimeout) touchstart touchmove(多个) touc ...
- eclipse中outline中图标的含义
outline: 实心的代表方法 空心的代表属性 绿色的圆表示公有public 黄色的菱形表示保护protect 红色的方形表示私有private 蓝色的三角表示default 图形后加字母S代表该属 ...
- PHP的版本选择 (转)
PHP的版本选择 http://yubosun.akhtm.com/tech/php-version.htm PHP版本特别多,特别杂,想自己搭一套php的运行环境可不是一件容易的事,稍不留神就遇到一 ...
- C语言学习笔记(二)_system系统调用及posix说明
1.9 System系统调用 System库函数的功能是执行操作系统的命令或者运行指定的程序.system库函数的调用需要#include<stdlib.h>这个头文件. #include ...
- iOS错误总结(三)
1.如果tableView设置为分组的样式(默认是有cell之间的分割线,可以设置颜色),默认有组以及组尾的高度 需要手动在组头组尾的代理方法中进行组高的设置(如果想设置为0,最好写0.01) 2.组 ...
- ANDROID调用webservice带soapheader验证
最近的一个项目中调用webservice接口,需要验证soapheader,现将解决方法记录如下:(网上资料出处太多,就不做引用,原作者如看到,如有必要添加请通知) 1.先看接口 POST /webs ...
- 从H264码流中获取视频宽高 (SPS帧)
获取.h264视频宽高的方法 花了2个通宵终于搞定.(后面附上完整代码) http://write.blog.csdn.net/postedit/7852406 图像的高和宽在H264的SPS帧中.在 ...
- R语言画全基因组关联分析中的曼哈顿图(manhattan plot)
1.在linux中安装好R 2.准备好画曼哈顿图的R脚本即manhattan.r,manhattan.r内容如下: #!/usr/bin/Rscript #example : Rscript plot ...
- js- this
this对象是基于函数在执行的环境绑定的. (一) this 在闭包环境中指向的对象. <Js高级程序设计>中提到: 每个函数在被调用时,其活动对象都会自动取得两个特殊变量:this和 ...