题意:给定一个{0,1,2,3,…,n-1}的排列 p。

一个{0,1,2 ,…,n-2}的排列 q 被认为是优美的排列,

当且仅当 q 满足下列条件 对排列 s={0,1,2,3,...,n-1}进行 n–1 次交换。

  1. 交换 s[q0],s[q0+1]
  2. 交换 s[q1],s[q1+1]



    最后能使得排列 s=p. 问有多少个优美的排列,答案对 10^9+7 取模。

    ( n<=5000)

    题解:这个题我们首先要知道一个性质,p排列的每一个数都是s排列经过变换后的最后状态,我们就能通过这些推出q数组中一些数的先后顺序

    然后通过这些我们就可以做dp了,f[i][j]表示前i个数,第i个数在前i个数中是第j小的。前缀和优化。时间复杂度:\(O(n^2)\)

    我讲的可能不是太好,安利机房一位学长的一篇博客:大佬的博客
#include<cstdio>
#include<algorithm>
using namespace std;
int n,p[5001],ans,pos[5001],mod=1e9+7,f[5001][5001],g[5001][5001];
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d",&p[i]),p[i]++;
for(int i=1;i<=n;i++)
if(p[i]>i)
{
if(i>1)if(pos[i-1]==1){printf("0\n");return 0;}else pos[i-1]=2;
for(int j=i;j<p[i]-1;j++)if(pos[j]==2){printf("0\n");return 0;}else pos[j]=1;
if(p[i]-1<=n-2)if(pos[p[i]-1]==1){printf("0\n");return 0;}else pos[p[i]-1]=2;
}
else if(p[i]<i)
{
if(p[i]>1)if(pos[p[i]-1]==2){printf("0\n");return 0;}else pos[p[i]-1]=1;
for(int j=p[i];j<i-1;j++)if(pos[j]==1){printf("0\n");return 0;}else pos[j]=2;
if(i-1<=n-2)if(pos[i-1]==2){printf("0\n");return 0;}else pos[i-1]=1;
}
f[1][1]=g[1][1]=1;
for(int i=2;i<n;i++)
for(int j=1;j<=i;j++)
{
if(pos[i-1]==1)f[i][j]=(f[i][j]+g[i-1][j-1])%mod;
if(pos[i-1]==2)f[i][j]=((f[i][j]+g[i-1][i-1]-g[i-1][j-1])%mod+mod)%mod;
g[i][j]=(g[i][j-1]+f[i][j])%mod;
}
for(int i=1;i<n;i++)ans=(ans+f[n-1][i])%mod;
printf("%d\n",ans);
}

最新文章

  1. JMeter学习-024-JMeter 命令行(非GUI)模式详解(二)-执行代理设置
  2. git ssh端口号变更之后所需要的修改
  3. 欧几里德与扩展欧几里德算法 Extended Euclidean algorithm
  4. Web网页的了解内容
  5. Mvc下异步断点续传大文件
  6. oracle模糊查询效率提高
  7. array_multisort 关联(string)键名保持不变,但数字键名会被重新索引。
  8. QQ空间魔力日志大全SduSRZ
  9. 消息中间件kafka+zookeeper集群部署、测试与应用
  10. Intellij IDEA 阅读源码的 4 个绝技,我必须分享给你!
  11. Linux(CentOS7)压缩和解压缩war包、tar包、tar.gz包命令
  12. linux中常见的命令
  13. 安装linux虚拟机配置静态ip(NAT模式)
  14. GloVe损失函数的理解
  15. 发现CVE-2018-11512-wityCMS 0.6.1 持久型XSS
  16. [转]PHP资源列表
  17. Springboot项目使用aop切面保存详细日志到ELK日志平台
  18. javascript获取事件源对象和产生事件的对象
  19. Vue.js checkbox 练习
  20. JavaWeb学习笔记(二十一)—— 监听器Listener

热门文章

  1. ABAP 动态where 使用
  2. 在图片上加字符-base64转图片-图片转base64
  3. 消息handler message 线程通信 空消息
  4. 后台管理微服务(二)——docker的使用
  5. 关于MySQL的information_schema库简单介绍及实际应用
  6. Java 出现“Illegal key size”错误的解决方案
  7. codeforces 465C.No to Palindromes! 解题报告
  8. IOC入门1
  9. CI 模型公用查询函数
  10. TX1 Gsteramer 环境配置