求1~n组成一个抖动序列的方案数

首先这种序列有一些非常妙妙但我发现不了的性质

1.对于一个抖动序列,如果i和i+1不相邻,则交换i和i+1,他还是个抖动序列

2.对于一个抖动序列,我把每个数拿n+1减一下(上下翻转),他还是个抖动序列,只不过波峰和波谷换了一下

3.对于一个抖动序列,我把它左右翻转,他还是个抖动序列

于是设f[i][j]是i个数中,排名为j的数在第一个位置、且它是波峰的方案数

那么答案就是$2\sum{f[N][i]}$(我把它翻一下不就有所有的第一个数作为波谷的情况了嘛)

然后有方程$f[i][j]=f[i][j-1]+f[i-1][j-1]$

考虑两种情况:

  1.j和j-1不相邻,由性质1这种情况的f[i][j]就是f[i][j-1]

  2.j和j-1相邻,也就是j-1在第二个位置,这种情况的f[i][j]就是f[i-1][j-1],就是不看j,然后把剩下的i-1个数拎出来,那j-1的排名还是j-1

合起来就是上面的方程

  1. #pragma GCC optimize(3)
  2. #include<bits/stdc++.h>
  3. #define pa pair<ll,ll>
  4. #define CLR(a,x) memset(a,x,sizeof(a))
  5. using namespace std;
  6. typedef long long ll;
  7. const int maxn=;
  8.  
  9. inline char gc(){
  10. return getchar();
  11. static const int maxs=<<;static char buf[maxs],*p1=buf,*p2=buf;
  12. return p1==p2&&(p2=(p1=buf)+fread(buf,,maxs,stdin),p1==p2)?EOF:*p1++;
  13. }
  14. inline ll rd(){
  15. ll x=;char c=gc();bool neg=;
  16. while(c<''||c>''){if(c=='-') neg=;c=gc();}
  17. while(c>=''&&c<='') x=(x<<)+(x<<)+c-'',c=gc();
  18. return neg?(~x+):x;
  19. }
  20.  
  21. int N,f[][maxn],P;
  22.  
  23. int main(){
  24. //freopen("","r",stdin);
  25. int i,j,k;
  26. N=rd(),P=rd();
  27. f[][]=;
  28. for(i=;i<=N;i++){
  29. for(j=;j<=i;j++){
  30. f[i&][j]=(f[i&][j-]+f[!(i&)][i-j+])%P;
  31. }
  32. }
  33. int ans=;
  34. for(i=;i<=N;i++)
  35. ans+=f[N&][i],ans%=P;
  36. printf("%d\n",ans*%P);
  37. return ;
  38. }

luogu2467/bzoj1925 地精部落 (dp)的更多相关文章

  1. Luogu2467 SDOI2010 地精部落 DP

    传送门 一个与相对大小关系相关的$DP$ 设$f_{i,j,0/1}$表示放了$i$个,其中最后一个数字在$i$个中是第$j$大,且最后一个是极大值($1$)或极小值时($0$)的方案数.转移: $$ ...

  2. 【题解】地精部落(DP)

    [题解]地精部落(DP) 设\(f_i\)表示强制第一个是谷的合法方案数 转移枚举一个排列的最大值在哪里,就把序列分成了互不相干的两个部分,把其中\(i-1\choose j-1\)的数字分配给前面部 ...

  3. BZOJ-1925 地精部落 烧脑DP+滚动数组

    1925: [Sdoi2010]地精部落 Time Limit: 10 Sec Memory Limit: 64 MB Submit: 1053 Solved: 633 [Submit][Status ...

  4. BZOJ 1925: [Sdoi2010]地精部落( dp )

    dp(i,j)表示1~i的排列中, 以1~j为开头且开头是下降的合法方案数 这种数列具有对称性, 即对于一个满足题意且开头是上升的n的排列{an}, 令bn = n-an+1, 那么{bn}就是一个满 ...

  5. bzoj1925 地精部落

    神题! 地精部落 内存限制:128 MiB 时间限制:1000 ms 标准输入输出     题目描述 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度 ...

  6. [BZOJ1925][SDOI2010]地精部落(DP)

    题意 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度为 N 的山脉 H可分 为从左到右的 N 段,每段有一个独一无二的高度 Hi,其中Hi是1到N ...

  7. wxy和zdy眼中的水题 地精部落 dp

    题目描述 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度为 N 的山脉 H可分 为从左到右的 N 段,每段有一个独一无二的高度 Hi,其中Hi是1到 ...

  8. 【BZOJ】1925: [Sdoi2010]地精部落 DP+滚动数组

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1925 题意:输入一个数N(1 <= N <= 4200),问将这些数排列成折线 ...

  9. [SDOI2010]地精部落 DP

    LG传送门 DP好题 题意很简单,就是求1-n的排列,满足一个数两边的数要么都比它大要么都比它小,求这样的排列个数对\(p\)取膜的值(为了表述简单,我们称这样的排列为波动序列). 这个题我第一眼看到 ...

随机推荐

  1. SQLServer数据库分页

    以  项目表 PM_Project  为例. PM_Project 全部内容如下(共6条数据): 一.Top – Not In - Top 方式分页 直接的,原始的,不采用函数,纯手动挡. 分步探索过 ...

  2. Day 6-3 粘包现象

    服务端: import socket import subprocess phone = socket.socket(family=socket.AF_INET, type=socket.SOCK_S ...

  3. DLNA流媒体设置

  4. CodeForces 113B Petr#

    题目链接:http://codeforces.com/problemset/problem/113/B 题目大意: 多组数据每组给定3个字符串T,Sbeg,Sed,求字符串T中有多少子串是以Sbeg开 ...

  5. mac 电脑 打开隐藏文件

    command +shift +. 第一次是打开,第二次是关闭

  6. Yii2的客户端验证

    如何配置Yii的客户端验证呢? 首先,应该配置验证规则的场景,即scenario 其次,应该配置验证规则,在验证规则中配置客户端验证 例如:

  7. js外部调用layui.use中的函数的写法

    layui模块化的写法固然不错,但也有让人不适应的一些地方 外部调用函数的写法就让人不太舒服 需要在函数名前面加上window这个前缀,就不太舒服 补充:window前缀,是全局变量的声明方式 如下: ...

  8. maven配置,jdk1.8

    <!-- 局部jdk配置,pom.xml中 --> <build> <plugins> <plugin> <groupId>org.apac ...

  9. TP5上传图片

    模板: <form action="{:url('Temp/addTempDo')}" enctype="multipart/form-data" met ...

  10. name设置id的方式 解决多个单选域冲突现象 同时有利于从动态网页取值