逆序对的相关问题:bzoj1831,bzoj2431
先从简单一点的bzoj2431入手;
n个数1~n已经限定了,所以
对于1~i-1,新加入i,最多可以增加i-1个逆序对,最少增加0个逆序对
f[i,j]表示1~i形成的序列逆序对为j的方案数
比较容易得出f[i,j]=Σf[i-1,k];
用前缀和优化即可
const mo=;
var f:array[..,..] of longint;
s:array[..] of longint;
i,j,k,n,m,p:longint; begin
readln(n,m);
k:=;
f[,]:=;
for i:= to n do
begin
k:=-k;
s[]:=f[-k,] mod mo;
for j:= to m do
begin
s[j]:=(s[j-]+f[-k,j]) mod mo;
f[k,j]:=;
end;
for j:= to m do
begin
p:=j-i+;
if p< then p:=;
f[k,j]:=(s[j]-s[p]+f[-k,p]) mod mo;
end;
end;
if f[k,m]< then f[k,m]:=f[k,m]+mo;
writeln(f[k,m] mod mo);
end.
bzoj2431
然后是bzoj1831
首先我们可以先求出固定的逆序对;
然后根据贪心的思想,不难得出需要填的数是不下降的
具体证明见:http://www.cnblogs.com/htfy/archive/2012/12/11/2813497.html
令big[i,j]表示第i为数字为j时,前面有多少个比它大的
small[i,j]表示第i为数字为j时,前面有多少个比它小的
f[i,j]表示第i个-1填j最小逆序对数目
得:f[i,j]=min(f[i-1,k])+small[loc[i],j]+big[loc[i],j];
我曾经讲过对于这样的dp怎么优化,具体见程序
var c,a,b:array[..] of longint;
f,small,big:array[..,..] of longint;
t,n,m,i,j,ans,s:longint; function lowbit(x:longint):longint;
begin
exit(x and (-x));
end; function ask(x:longint):longint;
begin
ask:=;
while x> do
begin
ask:=ask+c[x];
x:=x-lowbit(x);
end;
end; procedure add(x:longint);
begin
while x<=m do
begin
inc(c[x]);
x:=x+lowbit(x);
end;
end; begin
readln(n,m);
for i:= to n do
begin
read(a[i]);
if a[i]=- then
begin
inc(t);
b[t]:=i;
end;
end;
for i:=n downto do
begin
if a[i]<>- then
begin
add(a[i]);
s:=s+ask(a[i]-);
end
else begin
for j:= to m do
small[i,j]:=ask(j-);
end;
end;
fillchar(c,sizeof(c),);
for i:= to n do
begin
if a[i]<>- then add(a[i])
else begin
for j:= to m do
big[i,j]:=ask(m)-ask(j);
end;
end;
for i:= to t do
begin
f[i,]:=f[i-,];
for j:= to m do
f[i,j]:=min(f[i-,j],f[i,j-]); //优化
for j:= to m do
f[i,j]:=f[i,j]+big[b[i],j]+small[b[i],j];
end;
ans:=;
for i:= to m do
ans:=min(ans,f[t,i]);
writeln(ans+s);
end.
bzoj1831
总体来说,这两题不算太难,但我还是花了很多时间
是做题不够认真,戒之戒之
自己想出的零散的特点性质没有很好的整合,导致题目做不出来
逆序对的相关问题:bzoj1831,bzoj2431的更多相关文章
- [BZOJ1786][BZOJ1831]逆序对
[BZOJ1786][BZOJ1831]逆序对 试题描述 输入 输出 输入示例 - - 输出示例 数据规模及约定 见“输入” 题解 首先这题有一个性质,即,填的数从左到右一定不降.证明不妨读者自己yy ...
- 【BZOJ2431】逆序对数列(动态规划)
[BZOJ2431]逆序对数列(动态规划) 题面 Description 对于一个数列{ai},如果有i<j且ai>aj,那么我们称ai与aj为一对逆序对数.若对于任意一个由1~n自然数组 ...
- 【BZOJ1831】[AHOI2008]逆序对(动态规划)
[BZOJ1831][AHOI2008]逆序对(动态规划) 题面 BZOJ 洛谷 题解 显然填入的数拎出来是不降的. 那么就可以直接大力\(dp\). 设\(f[i][j]\)表示当前填到了\(i\) ...
- BZOJ2431 HAOI2009 逆序对数列 【DP】*
BZOJ2431 HAOI2009 逆序对数列 Description 对于一个数列ai{a_i}ai,如果有i<j且ai>aja_i>a_jai>aj,那么我们称aia ...
- bzoj2431: [HAOI2009]逆序对数列
dp. f[i][j]表示放置第i个数有j个逆序对的方案数. s[i][j]维护前缀和(f[i][0]~f[i][j]). 状态转移方程 f[i][j]=s[i-1][j]-s[i-1][max(j- ...
- bzoj2431:[HAOI2009]逆序对数列
单组数据比51nod的那道题还弱...而且连优化都不用了.. #include<cstdio> #include<cstring> #include<cctype> ...
- BZOJ1831: [AHOI2008]逆序对
1831: [AHOI2008]逆序对 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 341 Solved: 226[Submit][Status] ...
- 【BZOJ2431】【HAOI2009】逆序对数列 DP
题目大意 问你有多少个由\(n\)个数组成的,逆序对个数为\(k\)的排列. \(n,k\leq 1000\) 题解 我们考虑从小到大插入这\(n\)个数. 设当前插入了\(i\)个数,插入下一个数可 ...
- bzoj1831 逆序对 (dp+树状数组)
注意到,所有的-1应该是一个不降的序列,否则不会更优那就先求出来不是-1的的逆序对个数,然后设f[i][j]表示第i个-1放成j的前i个-1带来的最小逆序对数量这个可以树状数组来求 #include& ...
随机推荐
- 定时备份服务器数据库(借助windows任务计划以及mysqldump)
最近社区多了,考虑到数据的安全性,要每天备份一次数据库,以防万一: linux目前还不是很了解,先用windows的计划任务吧: 大体思路就是 借用windows的计划任务来执行备份远程数据库到本地: ...
- 代码分享:php判断数组是否有序
发布:脚本学堂/PHP编程 编辑:JB02 2013-12-17 14:59:02 [大 中 小] 转自:http://www.jbxue.com/article/14723.html如何判断 ...
- IE11下ASP.NET Forms身份认证无法保存Cookie的问题
IE11下ASP.NET Forms身份认证无法保存Cookie的问题 折腾了三四天,今天才找到资料,解决了. 以下会转贴,还没来得及深究,先放着,有空再学习下. ASP.NET中使用Forms身份认 ...
- 50个C++源码学习网站
C/C++是最主要的编程语言.这里列出了50名优秀网站和网页清单,这些网站提供c/c++源代码 .这份清单提供了源代码的链接以及它们的小说明.我已尽力包括最佳的C/C++源代码的网站.这不是一个完整的 ...
- c语言文件操作函数详解
一.文件操作注意点: 1 打开文件时,如果打开方式加“+”,表示该文件可以“写” ; 2 退出程序一般用exit函数,正常退出参数为0,非正常退出参数为正零值 ; 3 文件的读写操作:按字符.字符串. ...
- 在iframe结构中,如何使弹出层位于所有框架的上方(-)
在做后台管理页面的时候,经常用到iframe.虽说这东西有些过时,也不利于SEO,但是后台就是后台,不需要考虑那么多东西,综合来说,用iframe还是很适合后台管理界面的. 但是在遇到弹出层时,出现了 ...
- 【linQ】DataContext 入门 , 和 hql , jpql 一样好用
DataContext 和 LINQ结合后会有巨大的能量 public class UserDataContext : DataContext { public Table<User> U ...
- 硬盘4k对齐教程总结
4k对齐概念: 4K对齐相关联的是一个叫做“高级格式化”的分区技术.首先先来了解一下什么是叫做“4K 对齐”.其实“4K对齐”相关联的是一个叫做“高级格式化”的分区技术.“高级格式化”是国际硬盘设备与 ...
- Telerik RadGridView 右键菜单如何设置?
问题: 我想去掉红线框住的部分,希望有会的网友帮助我,谢谢! 解决方法: 默认: 修改: [利用 ContextMenuOpening 事件,对应你的项目,你要自己修改那判断的字符串(你的中文)] p ...
- Castle ActiveRecord简单介绍
Castle ActiveRecord框架是一个基于.NET的ORM框架,它实现了ActiveRecord设计模式.它本身就是基于NHibernate,只是封 装了NHibernate的大部分烦杂细节 ...