BZOJ 1831: [AHOI2008]逆序对
题目大意:
给出一个序列,有几个位置上的数字任意。求最小的逆序对数。
题解:
自己决定放置的数一定是单调不降的。不然把任意两个交换一下就能证明一定会增加逆序对。
然后就可以DP了,f[i][j]表示第i个位置放了j,前i个位置所能产生的最少逆序对数。
用前缀min优化一下就好了。
代码:
#include<cstdio>
#include<algorithm>
using namespace std;
int cnt,suml[10005][105],sumr[10005][105],a[10005],b[10005];
long long f[10005][105],g[10005][105];
int main(){
int n,k;
scanf("%d%d",&n,&k);
for (int i=1; i<=n; i++){
scanf("%d",&a[i]);
if (a[i]==-1) b[++cnt]=i;
}
for (int i=1; i<=n; i++)
for (int j=1; j<=k; j++){
suml[i][j]=suml[i-1][j];
if (a[i]>j) suml[i][j]++;
}
for (int i=n; i>=1; i--)
for (int j=1; j<=k; j++){
sumr[i][j]=sumr[i+1][j];
if (a[i]<j && a[i]!=-1) sumr[i][j]++;
}
for (int i=1; i<=cnt; i++) g[i][0]=1ll<<60;
for (int i=1; i<=cnt; i++)
for (int j=1; j<=k; j++){
f[i][j]=g[i-1][j]+suml[b[i]][j]+sumr[b[i]][j];
g[i][j]=min(g[i][j-1],f[i][j]);
}
long long ans=1ll<<60;
for (int i=1; i<=k; i++) ans=min(ans,f[cnt][i]);
for (int i=1; i<=n; i++) ans+=suml[i][a[i]];
printf("%lld\n",ans);
return 0;
}
BZOJ 1831: [AHOI2008]逆序对的更多相关文章
- 【BZOJ】1831: [AHOI2008]逆序对
		题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1831 考虑$-1$的位置上填写的数字一定是不降的. 令${f[i][j]}$表示$DP$到 ... 
- BZOJ1786: [Ahoi2008]Pair 配对/1831: [AHOI2008]逆序对
		这两道题是一样的. 可以发现,-1变成的数是单调不降. 记录下原有的逆序对个数. 预处理出每个点取每个值所产生的逆序对个数,然后dp转移. #include<cstring> #inclu ... 
- bzoj1786: [Ahoi2008]Pair 配对&&1831: [AHOI2008]逆序对
		一个自以为很对的东西,我们往-1放的数肯定是不增的. 然后就预处理一下,假如i这个位置放j会多多少逆序对. DP一下,我的复杂度应该是O(n*m^2)的,然而你随便搞都能省掉一个m吧,我算了算好像可以 ... 
- BZOJ1831: [AHOI2008]逆序对
		1831: [AHOI2008]逆序对 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 341 Solved: 226[Submit][Status] ... 
- bzoj1831: [AHOI2008]逆序对(DP+双精bzoj1786)
		1831: [AHOI2008]逆序对 Description 小可可和小卡卡想到Y岛上旅游,但是他们不知道Y岛有多远.好在,他们找到一本古老的书,上面是这样说的: 下面是N个正整数,每个都在1~K之 ... 
- 【BZOJ1831】[AHOI2008]逆序对(动态规划)
		[BZOJ1831][AHOI2008]逆序对(动态规划) 题面 BZOJ 洛谷 题解 显然填入的数拎出来是不降的. 那么就可以直接大力\(dp\). 设\(f[i][j]\)表示当前填到了\(i\) ... 
- BZOJ 3295 动态逆序对 | CDQ分治
		BZOJ 3295 动态逆序对 这道题和三维偏序很类似.某个元素加入后产生的贡献 = time更小.pos更小.val更大的元素个数 + time更小.pos更大.val更小的元素个数. 分别用类似C ... 
- 洛谷 P4280 bzoj1786 [AHOI2008]逆序对(dp)
		题面 luogu bzoj 题目大意: 给你一个长度为\(n\)的序列,元素都在\(1-k\)之间,有些是\(-1\),让你把\(-1\)也变成\(1-k\)之间的数,使得逆序对最多,求逆序对最少是多 ... 
- bzoj 3295 动态逆序对 CDQ分支
		容易看出ans[i]=ans[i-1]-q[i],q[i]为删去第i个数减少的逆序对. 先用树状数组算出最开始的逆序对,预处理出每个数前边比它大的和后边比它小的,就求出了q[i]的初始值. 设b[i] ... 
随机推荐
- css水平垂直居中块整理
			1.绝对定位+负margin 兼容性很好,但需要指定子块的高度和宽度,以及负margin .wp{ position: relative; width: 200px; height: 200px; b ... 
- 使用express+mongoDB搭建多人博客 学习(5)权限控制
			修改index.js如下: var express = require('express'); var router = express.Router(); var crypto=require('c ... 
- Java基础50题test2—输出素数
			[输出素数] 题目:判断 101-200 之间有多少个素数,并输出所有素数. 程序分析:判断素数的方法:用一个数分别去除 2 到 sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数 pu ... 
- 将centos6的php5.3升级为5.6
			在阿里云主机上,操作系统是Centos6,php版本是5.3.因为安装Yii2.0的需要,我要升级php为5.4.因为还有5.5和5.6,当然要升到高版本了.我决定升到5.6. 首先,按照这里的步 ... 
- jmeter中登录和提交收银出现的错误
			登录出现的错误 登录界面如图所示: 为了防止登录跳转的问题response code 302的问题,要设置 2.提交收银界面 当系统设置必须传送jison格式时,要在HTTP Header Manag ... 
- HDU 3033 I love sneakers! 我爱运动鞋 (分组背包+01背包,变形)
			题意: 有n<=100双鞋子,分别属于一个牌子,共k<=10个牌子.现有m<=10000钱,问每个牌子至少挑1双,能获得的最大价值是多少? 思路: 分组背包的变形,变成了相反的,每组 ... 
- hdu 1181 深搜
			中文题 深搜 许久没写鸟,卡在输入问题上... #include <iostream> #include <string> using namespace std; bool ... 
- 一张图看懂苹果MacBook所有屏幕分辨率
			苹果全新12寸超薄MacBook比曾经最薄的MacBook Air更薄,不过却配备了Retina视网膜显示屏.12英寸RetinaMacBook上的显示屏分辨率为2304*1440,虽然不如15寸和1 ... 
- Java创建图片文件缩略图
			public static void uploadImg(InputStream file, String filePath, String fileName, int widthdist, int ... 
- struts2的动态方法配置
			动态方法调用配置 <package name="test" extends="struts-default"> <aciton name=&q ... 
