【题解】逆序排列 [51nod1020]

传送门:逆序排列 \([51nod1020]\)

【题目描述】

共 \(T\) 组测试点,每一组给出 \(2\) 个整数 \(n\) 和 \(k\),在 \([1,n]\) 共 \(n\) 个数字的全排列中,逆序数为 \(k\) 的排列种数,答案对 \(1e9+7\) 取模。

【样例】

样例输入:
1
4 3 样例输出:
6

【数据范围】

\(100\%\) \(1 \leqslant T \leqslant 10000,\) \(1 \leqslant N \leqslant 1000,\) \(1 \leqslant K \leqslant 20000\)

【分析】

用 \(dp[i][j]\) 表示 \([1,i]\) 的排列中逆序对数为 \(j\) 的排列种数,为方便枚举,用 \(ss[i]\) 表示长度为 \(i\) 的排列总数\((ss[i]=min\{K,\frac{i*(i-1)}{2}\}\)。

对于数字 \(i\) 来说,在一个 \([1,i-1]\) 的排列中它有 \(i\) 个位置可以加入,加下 \(i\) 之后新构成的逆序对数 \(k\in [0,i-1]\) 。

那么 \(dp\) 方程就出来了:\(dp[i][j]+=dp[i-1][j-k]\),其中 \(0 \leqslant j \leqslant ss[i],\) \(0 \leqslant j-k \leqslant ss[i-1]\) ,所以 \(max\{0,j-ss[i-1]\} \leqslant k \leqslant min\{j,i-1\}\) 。

即 \(dp[i][j]=\sum_{k=max\{0,j-ss[i-1]\}}^{min\{j,i-1\}}dp[i-1][j-k]\) 。

时间复杂度过高,要用前缀和优化一下,\(dp[i][j]=S[j-max(0,j-ss[i-1])]-S[j-min(i-1,j)-1]\),其中 \(S[i]=\sum_{j=0}^{i}dp[i-1][j]\) 。

但是前缀和下边界可能会取到 \(0\),减了 \(1\) 之后就成了 \(-1\),\(S[-1]\)是不存在的,所以每一次写 \(S[x]\) 都要改成 \(S[x+1]\)

还要先预处理答案,询问时直接 \(O(1)\) 查询。

时间复杂度为 \(O(NK)\) 。

【Code】

#include<algorithm>
#include<cstring>
#include<cstdio>
#define LL long long
#define Re register int
using namespace std;
const int N=1003,M=2e4+3,P=1e9+7;
int T,n,K,S[M],ss[N],dp[N][M];
inline void in(Re &x){
int f=0;x=0;char c=getchar();
while(c<'0'||c>'9')f|=c=='-',c=getchar();
while(c>='0'&&c<='9')x=(x<<1)+(x<<3)+(c^48),c=getchar();
x=f?-x:x;
}
int main(){
n=1000,K=20000;
for(Re i=2;i<=n;++i){
ss[i]=i*(i-1)>>1;
if(ss[i]>K){for(Re j=i;j<=n;++j)ss[j]=K;break;}
}
for(Re i=1;i<=n;++i)dp[i][0]=1;
for(Re j=0;j<=ss[2];++j)(S[j+1]=S[j-1+1]+dp[1][j])%=P;
for(Re i=2;i<=n;++i){
for(Re j=1;j<=ss[i];++j)(dp[i][j]=(S[j-max(0,j-ss[i-1])+1]-S[j-min(i-1,j)-1+1]+P)%P)%=P;
for(Re j=0;j<=ss[i+1];++j)(S[j+1]=S[j-1+1]+dp[i][j])%=P;
}
in(T);while(T--)in(n),in(K),printf("%d\n",dp[n][K]);
}

最新文章

  1. 微信小程序:原生热布局终将改变世界
  2. Mac下安装 PIL
  3. Maven的pom.xml标签详解
  4. python 登陆接口
  5. CF 256D. Good Sequences(DP)
  6. Kinect 图像帧的格式
  7. NEC学习 ---- 模块 -简易文字链接列表
  8. poj 1050 To the Max
  9. jq层次选择器
  10. php引用传值
  11. ExtJs005继承
  12. delphi 怎么将一个文件流转换成字符串(String到流,String到文件,相互转化)
  13. 我是这样发现ISP劫持HTTP请求的
  14. myeclipse 2014 Customize Perspective 失效
  15. Java异常处理-----finally
  16. Golang 通用连接池库 Golang-Pool
  17. Json&amp;xml分析~
  18. javax.inject包
  19. Linux下apache支持PHP配置
  20. MRPT编译

热门文章

  1. loadrunner安装和应用
  2. Spark调用Linux命令实现解压和压缩功能
  3. 前后端分离-Restful最佳实践
  4. 剑指offer-08 二叉树的下一个节点
  5. spring boot 程序启动缓慢的问题(二)
  6. mysql在windows下安装(含客户端工具)
  7. linux防止恶意采集攻防战
  8. 微信小程序自动化jest模拟场景/切出/切入
  9. 剑指offer15 二进制中1的个数
  10. PATA1031 Hello World for U