博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[luoguP2513] [HAOI2009]逆序对数列(DP)
阅读量:5340 次
发布时间:2019-06-15

本文共 974 字,大约阅读时间需要 3 分钟。

 

f[i][j]表示前i个数,逆序对数为j的答案

则DP方程为:

f[1][0] = 1;    for(i = 2; i <= n; i++)        for(j = 0; j <= m; j++)            for(k = j; k < j + i; k++)                f[i][k] = (f[i][k] + f[i - 1][j]) % p;

但是会超时

所以搞个前缀和优化一下

#include 
#include
#define N 2001#define p 10000int n, m;int f[N][N], sum[N][N];inline int read(){ int x = 0, f = 1; char ch = getchar(); for(; !isdigit(ch); ch = getchar()) if(ch == '-') f = -1; for(; isdigit(ch); ch = getchar()) x = (x << 1) + (x << 3) + ch - '0'; return x * f;}int main(){ int i, j, k; n = read(); m = read(); f[1][0] = 1; for(i = 0; i <= m; i++) sum[1][i] = 1; for(i = 2; i <= n; i++) for(j = 0; j <= m; j++) { if(j - i + 1 > 0) f[i][j] = (f[i][j] + ((sum[i - 1][j] - sum[i - 1][j - i]) % p + p) % p) % p; else f[i][j] = (f[i][j] + sum[i - 1][j]) % p; sum[i][j] = (sum[i][j - 1] + f[i][j]) % p; } printf("%d\n", f[n][m]); return 0;}

  

转载于:https://www.cnblogs.com/zhenghaotian/p/7350661.html

你可能感兴趣的文章
linux的子进程调用exec( )系列函数
查看>>
MSChart的研究
查看>>
C# 索引器
查看>>
MySQLdb & pymsql
查看>>
zju 2744 回文字符 hdu 1544
查看>>
【luogu P2298 Mzc和男家丁的游戏】 题解
查看>>
前端笔记-bom
查看>>
MATLAB作图方法与技巧(一)
查看>>
上海淮海中路上苹果旗舰店门口欲砸一台IMAC电脑维权
查看>>
Google透露Android Market恶意程序扫描服务
查看>>
给mysql数据库字段值拼接前缀或后缀。 concat()函数
查看>>
迷宫问题
查看>>
【FZSZ2017暑假提高组Day9】猜数游戏(number)
查看>>
泛型子类_属性类型_重写方法类型
查看>>
eclipse-将同一个文件分屏显示
查看>>
对闭包的理解
查看>>
练习10-1 使用递归函数计算1到n之和(10 分
查看>>
Oracle MySQL yaSSL 不明细节缓冲区溢出漏洞2
查看>>
windows编程ASCII问题
查看>>
.net webService代理类
查看>>