swap(2018.10.16)
题意:给定一个{0,1,2,3,…,n-1}的排列 p。
一个{0,1,2 ,…,n-2}的排列 q 被认为是优美的排列,
当且仅当 q 满足下列条件 对排列 s={0,1,2,3,...,n-1}进行 n–1 次交换。
- 交换 s[q0],s[q0+1]
- 交换 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);
}
swap(2018.10.16)的更多相关文章
- 2018.10.16 uoj#340. 【清华集训2017】小 Y 和恐怖的奴隶主(矩阵快速幂优化dp)
传送门 一道不错的矩阵快速幂优化dpdpdp. 设f[i][j][k][l]f[i][j][k][l]f[i][j][k][l]表示前iii轮第iii轮还有jjj个一滴血的,kkk个两滴血的,lll个 ...
- 在 .NET项目中使用 Redis(2018.10.16)
1. 打开NuGet管理器搜索redis,安装:“StackExchange.Redis” 2. 配置 Web.config 文件 <connectionStrings> <add ...
- 2018.10.16 spoj Can you answer these queries V(线段树)
传送门 线段树经典题. 就是让你求左端点在[l1,r1][l1,r1][l1,r1]之间,右端点在[l2,r2][l2,r2][l2,r2]之间且满足l1≤l2,r1≤r2l1\le l2,r1 \l ...
- 2018.10.16 NOIP模拟 长者(主席树+hash)
传送门 考试的时候开始sb的以为需要可持久化trietrietrie树,发现建树时空都是O(n2)O(n^2)O(n2)的. 然后发现由于每次只从原来的字符串改一个字符. 因此直接主席树维护区间has ...
- 2018.10.16 NOIP模拟 华莱士(并查集)
传送门 按照题意模拟维护最小的环套树森林就行了. 然而考试的时候naivenaivenaive瞎写了一个错误的贪心. 代码
- 2018.10.16 NOIP模拟 膜法(组合数学)
传送门 原题,原题,全TM原题. 不得不说天天考原题. 其实这题我上个月做过类似的啊,加上dzyodzyodzyo之前有讲过考试直接切了. 要求的其实就是∑i=lr(ii−l+k)\sum _{i=l ...
- 2018.10.16 NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 + 20 = 220\) 实际得分:\(100 + 100 + 30 = 230\) 辣鸡模拟赛.. T1T2都是一眼题,T3考验卡常数还只有一档暴力分. ...
- 2018.10.16 Java的IO与NIO
IO流学习总结 一 Java IO,硬骨头也能变软 二 java IO体系的学习总结 三 Java IO面试题 NIO与AIO学习总结 一 Java NIO 概览 二 Java NIO 之 Buffe ...
- moiezen(2018.10.16)
题意:有n件行李,编号为1~n.行李的质量是模 P 意义下的(P不一定是质数).有 k 个背包,要装下这些行李,为了方便在背包中找行李,每个背包中的行李编号是连续的,允许有背包为空.我们想让最重的背包 ...
随机推荐
- SQL Server 2005中top关键字的用法
1.返回N条记录数 select top n * from <表名> [查询条件] 2.返回总结果集中指定百分比记录数 select top n percent * from <表名 ...
- UVA 10951 - Polynomial GCD(数论)
UVA 10951 - Polynomial GCD 题目链接 题意:给定两个多项式,求多项式的gcd,要求首项次数为1,多项式中的运算都%n,而且n为素数. 思路:和gcd基本一样,仅仅只是传入的是 ...
- sdut oj 1163 C语言实验——排列 (当初不会递归生成排列,这个题目现在才补上 刘汝佳给出了写法 *【模板】 当然有生成全排列的函数存在 )
C语言实验——排列 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 有4个互不相同的数字,请按序输出由其中三个不重复数字组成的排列 ...
- Codeforces Round #379 (Div. 2) D. Anton and Chess —— 基础题
题目链接:http://codeforces.com/contest/734/problem/D D. Anton and Chess time limit per test 4 seconds me ...
- Java8初体验(2):Stream语法详解
原文出处: 一冰_天锦 上篇文章Java8初体验(1):lambda表达式语法比较详细的介绍了lambda表达式的方方面面,细心的读者会发现那篇文章的例子中有很多Stream的例子.这些Stream的 ...
- codeforces 466A. Cheap Travel 解题报告
题目链接:http://codeforces.com/problemset/problem/466/A 题目意思:一个 ride 需要 a 卢布,m 个 ride 需要 b 卢布,这两种方案都可以无限 ...
- IntelliJ IDEA 2016.1注册码
IntelliJ IDEA 2016.1刚发布不久,破解注册的方法是在太少,15的注册URL也不管用,真是很头疼... 幸好发现一枚注册码,感谢sanshi的奉献精神!!! 原文链接: http ...
- 静态路由配置及RIP配置实验
[实验环境] Packet Trace 5.3 模拟软件. [实验步骤] 1.首先要进行IP地址规划.(例如下图格式) 网络名 网络地址 子网掩码 网关 主机IP vlan1 10.10.1.0 25 ...
- Hihocoder 1625 : 重复字符串匹配 (KMP)
描述 给定两个字符串A和B,请你求出字符串A最少重复几次才能使得B是A的子串. 例如A="hiho",B="hohihohi".则A重复3次之后变为" ...
- hdu 2899 Strange fuction —— 模拟退火
题目:http://acm.hdu.edu.cn/showproblem.php?pid=2899 模拟退火: 怎么也过不了,竟然是忘了写 lst = tmp ... 还是挺容易A的. 代码如下: # ...