BZOJ2431_逆序对数列_KEY
转自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的更多相关文章
- bzoj2431:[HAOI2009]逆序对数列
单组数据比51nod的那道题还弱...而且连优化都不用了.. #include<cstdio> #include<cstring> #include<cctype> ...
- 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 ...
- 2431: [HAOI2009]逆序对数列
2431: [HAOI2009]逆序对数列 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 954 Solved: 548[Submit][Status ...
- 【BZOJ2431】逆序对数列(动态规划)
[BZOJ2431]逆序对数列(动态规划) 题面 Description 对于一个数列{ai},如果有i<j且ai>aj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组 ...
- P2513 [HAOI2009]逆序对数列
P2513 [HAOI2009]逆序对数列 题目描述 对于一个数列{ai},如果有iaj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组成的数列,可以很容易求出有多少个逆序对数.那 ...
- bzoj千题计划153:bzoj2431: [HAOI2009]逆序对数列
http://www.lydsy.com/JudgeOnline/problem.php?id=2431 dp[i][j] 表示i的排列,有j个逆序对的方案数 加入i+1,此时i+1是排列中最大的数, ...
- BZOJ2431 HAOI2009 逆序对数列 【DP】*
BZOJ2431 HAOI2009 逆序对数列 Description 对于一个数列ai{a_i}ai,如果有i<j且ai>aja_i>a_jai>aj,那么我们称aia ...
- 洛谷P2513 [HAOI2009]逆序对数列
P2513 [HAOI2009]逆序对数列 题目描述 对于一个数列{ai},如果有i<j且ai>aj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组成的数列,可以很容易 ...
- bzoj2431: [HAOI2009]逆序对数列(前缀和优化dp)
2431: [HAOI2009]逆序对数列 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 2312 Solved: 1330[Submit][Stat ...
随机推荐
- WeQuant交易策略—KDJ
KDJ随机指标策略策略介绍KDJ指标又叫随机指标,是一种相当新颖.实用的技术分析指标,它起先用于期货市场的分析,后被广泛用于股市的中短期趋势分析,是期货和股票市场上最常用的技术分析工具.随机指标KDJ ...
- ABP+AdminLTE+Bootstrap Table权限管理系统第二节--在ABP的基础做数据库脚本处理
返回总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期 第一点,上一篇文章中我们讲到codefirst中一些问题包括如图,codefirst在每次执行命令的时候会生成新的 ...
- 剑指Offer第36题—Java版
本题使用归并排序的思想,结合归并排序,写出的算法解. //数组中的逆序对 public static int InversePairs(int[] array){ if(array==null||ar ...
- CSS布局技巧大全
参考资料: http://www.imooc.com/article/2235 单列布局 水平居中 父元素text-align:center;子元素:inline-block; 优点:兼容性好: 不足 ...
- informatica9 安装下载,安装教程 介质(文章和视频教程)(csdn讲师:Array)
Informatica学习: 参考文献:视频参考地址:http://edu.csdn.net/course/detail/5034,ETL之informatica9通关班(第二期) 1.安装介质的获 ...
- Spring框架Controller层(表现层)针对方法参数是Bean时HttpServletRequest绑定参数值问题解释
在做项目的时候,有一个需求是将数据库中的信息封装到实体类返回到jsp界面 传过来的参数只是实体类的id属性,然后根据id属性去查数据库,事情就是这样,然后 结果遇到很奇怪的事情,在jsp页面中使用EL ...
- 【全面总结】js获取元素位置大小
[js获取元素位置+元素大小]全面总结 目录 1.关于offset offsetParent(只读) offsetTop(只读) offsetLeft(只读) offsetHeight(只读) off ...
- 对eigrp默认网络的理解!
EIGRP 默认网络设置的个人总结 (了解即可) //该机制同rip和ospf的default-informationoriginate,原理相同,只是配置格式不同. //!!(唯一作用)该命令起到减 ...
- 部署自己的GitLab
先说明一下自己的想法:无论怎么样,个人确实先不想升级到centos7上面,因为我觉得centos6还是比较占用资源少的,而且作为生产环境,centos6完全够用了. 实验测试环境: * centos ...
- Matlab生成.exe可执行程序
由于在教学过程中需要演示Matlab程序,而教学机又未安装Matlab程序,因此有必要将Matlab程序生成.exe可执行程序,便于直接执行. 在Matlab中提供了Complier,可直接使用. ( ...