链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1996

Description

Input

Output

Sample Input

4
1701 1702 1703 1704

Sample Output

8

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 合唱队的更多相关文章

  1. BZOJ 1996: [Hnoi2010]chorus 合唱队(dp)

    简单的dp题..不能更水了.. --------------------------------------------------------------- #include<cstdio&g ...

  2. 【BZOJ】1996: [Hnoi2010]chorus 合唱队【区间dp】

    1996: [Hnoi2010]chorus 合唱队 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 2088  Solved: 1371[Submit][ ...

  3. bzoj 1996: [Hnoi2010]chorus 合唱队

    Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Output 8 HINT Source 因为只会在区间的两端进行 ...

  4. BZOJ 1996: [Hnoi2010]chorus 合唱队(区间dp)

    题目: https://www.lydsy.com/JudgeOnline/problem.php?id=1996 题解: 这题刚拿到手的时候一脸懵逼qwq,经过思考与分析(看题解),发现是一道区间d ...

  5. 1996: [Hnoi2010]chorus 合唱队 - BZOJ

    Description Input Output Sample Input41701 1702 1703 1704Sample Output8HINT 水题,区间dp,f[l,r,k]表示区间[l,r ...

  6. bzoj1196:[Hnoi2010]chorus 合唱队

    这数据范围明显的区间dp啊...然而据说二维会wa...那就写三维把... #include<cstdio> #include<cstring> #include<cct ...

  7. 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 ...

  8. 【BZOJ1996】[Hnoi2010]chorus 合唱队 区间DP

    [BZOJ1996][Hnoi2010]chorus 合唱队 Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Ou ...

  9. BZOJ1996 [Hnoi2010]chorus 合唱队

    很容易想到区间DP 然后发现这个区间只和圆序列的最后一个数有关,而原序列的最后一个数只可能是现在区间的头或者尾 令$f[i][j][0/1]$表示在区间$[i, j]$之间,原序列的最后一个数是当前区 ...

随机推荐

  1. jquery ajax get /post

    $.get(URL,callback); $("button").click(function(){ $.get("demo_test.asp",functio ...

  2. PHP开发网站之微信登录、绑定

    )))刷新access_token()); ); ); curl_setopt($curlobj, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($curlo ...

  3. 9.8 js进阶总结3

    DOM文档对象模型 DOM(document object model)文档对象模型,它定义了操作文档对象的接口. DOM 把一份html文档表示为一棵家谱树,使用parent(父),child(子) ...

  4. 9.7 js进阶总结2

    数组元素添加 将一个或多个新元素添加到数组结尾,并返回数组新长度 var week_len = week.push(‘星期四’,‘星期五’); 将一个或多个新元素添加到数组开始,数组中的元素自动后移, ...

  5. Linux 驱动学习笔记05--字符驱动实例,实现一个共享内存设备的驱动

    断断续续学驱动,好不容易有空,做了段字符驱动的例子.主要还是跟书上学习在此记录下来,以后说不定能回过头来温故知新. 首先上驱动源码 gmem.c: /************************* ...

  6. BASE64编码和解码(VC源代码) 并 内存加载 CImage 图像

      BASE64可以用来将binary的字节序列数据编码成ASCII字符序列构成的文本.完整的BASE64定义可见 RFC1421和 RFC2045.编码后的数据比原始数据略长,为原来的4/3.在电子 ...

  7. Graded Browser Support

    ( The YUI Target Environments Matrix is here) About the Browser Test Baseline and Operating Systems ...

  8. Tomcat启动时项目重复加载,导致资源初始化两次的问题

    http://blog.csdn.net/testcs_dn/article/details/38855641

  9. Cdnbes负载均衡的权重用法解释

    (1)相同域名添加两条记录,解析不同的ip,可以设置权重,比如权重2,就意思占百分之20 ,数字越大,优先级越大 (2)这个hash 如果用户访问的源是挂掉的.会去第二个源

  10. [C语言]关于struct和typedef struct

    在C中定义一个结构体类型要用typedef: *************************************************************************** t ...