转自YXDs

题目传送门
不知道今天是怎么了,可能是空调吹多了吧,一直不在状态,连递推题我都做不来了……(扎Zn了老Fe……)
然而,不管环境如何恶劣,我们仍要努力学习,为了自己的明天而奋斗。(说的好像跟真的一样)
其实这题就是一个递推,现在我们考虑第i个数,定义f[i][j]表示序列里有i个数,逆序对的组数为j的方案数。
因为第i个数的权值就是i,则不管第i个数插到序列里的哪个位置,都会和在它后面的数形成逆序对,因此第i个数插到序列里最多形成i-1个逆序对,最少形成0个。
所以,我们就得到了递推公式:f[i][j]=Σf[i-1][j-k] (j-i+1<=k<=j)
但是现在的时间复杂度仍然是O(n^3)的,n的范围是1000,铁定TLE。
但是看到上面的递推式中有Σ,于是我们就想到了前缀和,降掉一维的复杂度,过掉这道题非常轻松。
另外,由递推式可发现,第i个数的所有逆序对方案数都只跟第i-1个数的逆序对方案数有关,因此可以使用滚动数组来存储,减少内存的使用。
(虽然在这题里并没有什么卵用,在BZOJ上实测出来大概省了80+kb的空间吧……)
注意:本题需要考虑中途答案为负的情况,虽然只要加上p就行了,但是一定要注意考虑,别忘了。
O(n^3)算法(主要是怕自己会忘):

#include <cstdio>
#define p 10000
using namespace std; int n,m,f[][]; int main(void){
scanf("%d%d",&n,&m);
for (int i=; i<=n; ++i) f[i][]=;
for (int i=; i<=n; ++i)
for (int j=; j<=m; ++j)
for (int k=; k<=j&&k<i; ++k)
f[i][j]=(f[i][j]+f[i-][j-k])%p;
printf("%d",f[n][m]);
return ;
}

N^3

O(n^2)算法(AC代码):

#include <cstdio>
#define p 10000
using namespace std; int n,m,f[],c[]; int main(void){
scanf("%d%d",&n,&m);
f[]=;
for (int i=; i<=n; ++i){
for (int j=; j<=m; ++j) c[j]=(c[j-]+f[j])%p;
for (int j=; j<=m; ++j)
if (j>) if (j>=i) f[j]=(c[j]-c[j-i]+p)%p;
else f[j]=c[j];
else f[j]=;
}
printf("%d",f[m]);
return ;
}

AC

附:公式改进法,我在洛谷上看见的。
由上面的那个递推公式可知:f[i][j]=f[i-1][j]+f[i-1][j-1]+…+f[i-1][j-i+1]
又f[i][j-1]=f[i-1][j-1]+f[i-1][j-2]+…+f[i-1][j-i]
所以f[i][j]=f[i-1][j]+f[i][j-1]-f[i-1][j-i]
虽然这个公式的变形在这题中并没有什么特别大的用处,但是这种思想是非常好的,常常可以把一些非常复杂的公式变得简单些,公式的特点也更明显一些。
所以我们还是有必要学习一下这种思想的。
然后就是递推了,其他都和上面的代码差不多的。

#include <cstdio>
#define p 10000
using namespace std; int n,m,f[][]; int main(void){
scanf("%d%d",&n,&m);
f[][]=;
for (int i=; i<=n; ++i)
for (int j=; j<=m; ++j)
if (j>) if (j>=i) f[i%][j]=(f[(i-)%][j]+f[i%][j-]-f[(i-)%][j-i]+p)%p;
else f[i%][j]=(f[(i-)%][j]+f[i%][j-])%p;
else f[i%][j]=(f[(i-)%][j])%p;
printf("%d",f[n%][m]>?f[n%][m]:-);
return ;
}

AC-公式改进法

BZOJ2431_逆序对数列_KEY的更多相关文章

  1. bzoj2431:[HAOI2009]逆序对数列

    单组数据比51nod的那道题还弱...而且连优化都不用了.. #include<cstdio> #include<cstring> #include<cctype> ...

  2. BZOJ 2431: [HAOI2009]逆序对数列( dp )

    dp(i,j)表示1~i的全部排列中逆序对数为j的个数. 从1~i-1的全部排列中加入i, 那么可以产生的逆序对数为0~i-1, 所以 dp(i,j) = Σ dp(i-1,k) (j-i+1 ≤ k ...

  3. 2431: [HAOI2009]逆序对数列

    2431: [HAOI2009]逆序对数列 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 954  Solved: 548[Submit][Status ...

  4. 【BZOJ2431】逆序对数列(动态规划)

    [BZOJ2431]逆序对数列(动态规划) 题面 Description 对于一个数列{ai},如果有i<j且ai>aj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组 ...

  5. P2513 [HAOI2009]逆序对数列

    P2513 [HAOI2009]逆序对数列 题目描述 对于一个数列{ai},如果有iaj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组成的数列,可以很容易求出有多少个逆序对数.那 ...

  6. bzoj千题计划153:bzoj2431: [HAOI2009]逆序对数列

    http://www.lydsy.com/JudgeOnline/problem.php?id=2431 dp[i][j] 表示i的排列,有j个逆序对的方案数 加入i+1,此时i+1是排列中最大的数, ...

  7. BZOJ2431 HAOI2009 逆序对数列 【DP】*

    BZOJ2431 HAOI2009 逆序对数列 Description 对于一个数列ai{a_i}ai​,如果有i<j且ai>aja_i>a_jai​>aj​,那么我们称aia ...

  8. 洛谷P2513 [HAOI2009]逆序对数列

    P2513 [HAOI2009]逆序对数列 题目描述 对于一个数列{ai},如果有i<j且ai>aj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组成的数列,可以很容易 ...

  9. bzoj2431: [HAOI2009]逆序对数列(前缀和优化dp)

    2431: [HAOI2009]逆序对数列 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 2312  Solved: 1330[Submit][Stat ...

随机推荐

  1. java的引用数据类型,你知道吗???

    有些人很清楚java的八种基本数据类型,但说到java的引用数据类型就不清楚了. Java的数据类型分为两大类,即基本数据类型和引用数据类型,在基本数据类型中有8种 基本数据类型(逻辑型-boolea ...

  2. python+selenium自动化软件测试(第14章):基础实战(1)

    #coding=utf- from selenium import webdriven from selenium.webdriver.common.by import By from seleniu ...

  3. Keep in Mind

    Do not undermine your worth by comparing yourself with others.It is because we are different and eac ...

  4. Java基础语法(三)---数组

    一.概念         同一种类型数据的集合.简单的来说就是一容器,用来装东西的. 使用数组的好处:可以自动给数组中的元素从0开始编号,方便操作这些元素. 二.一维数组的格式 格式1:元素类型 [ ...

  5. Python验证码通过pytesser识别

    Python安装包: 需要安装的包主要有两个: PIL 和 pytesser .tesseract (1).安装PIL:下载地址:http://www.pythonware.com/products/ ...

  6. links

    http://stackoverflow.com/questions/23469784/com-fasterxml-jackson-databind-exc-unrecognizedpropertye ...

  7. Varnish后端主机的健康状态检查

    author:JevonWei 版权声明:原创作品 配置后端主机的Health Check 环境 Varnish 192.168.198.139 图片服务端 192.168.198.120 程序服务端 ...

  8. 【ASP.NET MVC】View与Controller之间传递数据

    1   概述 本篇文章主要从操作上简要分析Controller<=>View之间相互传值,关于页面之间传值,如果感兴趣,可参考我另外一篇文章ASP.NET 页面之间传值的几种方式 . Co ...

  9. 理解 angular 的路由功能

    相信很多人使用angular 都是因为他路由功能而用的 深入理解ANGULARUI路由_UI-ROUTER 最近在用 ionic写个webapp 看到几个demo中路由有好几种,搞的有点晕,查下资料研 ...

  10. css中使用变量

    2017年3月,微软宣布 Edge 浏览器将支持 CSS 变量.这个重要的 CSS 新功能,所有主要浏览器已经都支持了. 声明css变量的时候,变量名前面要加两根连词线(--).变量名大小写敏感,-- ...