链接: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. android_demo之生成颜色布局

    前面学习了动态生成表格,不单单是要动态生成控件,也同时生成一个事件. 接下来用个小小栗子去了解这个知识点. <LinearLayout xmlns:android="http://sc ...

  2. Linux 常用命令 :cd命令

    ls命令是linux下最常用的命令.ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单. 通过ls 命令不仅可以查看linu ...

  3. web前端安全 XSS跨站脚本 CSRF跨站请求伪造 SQL注入

    web安全,从前端做起,总结下web前端安全的几种技术: 1,XSS XSS的全称是Cross Site Scripting,意思是跨站脚本,XSS的原理也就是往HTML中注入脚本,HTML指定了脚本 ...

  4. error C4996: 'fopen': This function or variable may be unsafe.

    vs2013中错误提示信息: error C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s ...

  5. @ViewDebug.ExportedProperty的使用

    原文链接:http://daemon369.github.io/android/2014/06/12/android-viewdebug-exportedproperty/ http://www.eo ...

  6. 什么是IO流 \ 以及文件输入输出

    一.IO流的分类: 流按照操作数据的类型分为两种:字节流:字符流. 1.什么是字节流:读取的是文件的二进制数据,不会对二进制做处理,不会解析成看得懂的数据. 2.什么是字符流:读取的是文件的二进制数据 ...

  7. [题解]洛谷月赛 Hello World(升级版)

    题目背景 T1答案要mod1000000007(10^9+7),请重新提交,非常抱歉! 一天,智障的pipapi正在看某辣鸡讲义学程序设计. 题目描述 在讲义的某一面,他看见了一篇文章.这篇文章由英文 ...

  8. 【译】RabbitMQ:工作队列(Work Queue)

    在第一篇我们写了两个程序通过一个命名的队列分别发送和接收消息.在这一篇,我们将创建一个工作队列在多个工作线程间分发耗时的工作任务. 工作队列的核心思想是避免立刻处理资源密集型任务导致必须等待其执行完成 ...

  9. Robotium-无源码测试

    [总结] 1.新建工程,选择Android Application Project,选择This Project: PS:新建测试工程时报NULL错误,新建一个Android工程,然后再按上诉步骤建立 ...

  10. Spring SpringMVC和Mybatis整合

    1.引入所要的jar包 2.创建Mybatis的sqlMapConfig.xml配置文件,该文件中可以配置mybaits的相关参数,数据源不在这里配置. <?xml version=" ...