loj

description

给你一个排列\(h_i\),你需要交换任意两个位置上的数使得交换后排列的逆序对数最少。

\(n \le 3\times 10^5\)

sol

首先可以发现,如果交换两个位置\(i,j(h_i>h_j)\),那么逆序对数的减小量就是满足\(i<k<j\)且\(h_j<h_k<h_i\)的\(k\)的数量乘\(2\)。这相当于一个二维数点的问题。

理性分析一下,枚举出来的\(i\)一定是前缀最大值,\(j\)一定是后缀最小值,不然这个矩形内包含的点的数量一定不是最多的。

那么我们就构造出了一个满足前缀最大的集合\(U\)和一个满足后缀最小的集合\(D\),现在要从两个集合中各选出一个构成一个矩形,最大化其中的点数。注意这两个集合中的\(h_i\)都是单调递增的。

我们考虑每一个点\((x,h_x)\)会出现在哪些矩形中。

在\(U\)中二分找到最小的\(l\)满足\(h_l>h_x\),在\(D\)中二分找到最小的\(r\)满足\(h_r<h_x\),那么要使点\((x,h_x)\)被包含在\((i,j)\)构成的矩形内部的条件就是:\(i\in[l,x-1],j\in[x+1,r]\)。

把点转化为矩阵,问题变成求矩形覆盖的最大值,线段树维护扫描线即可。

复杂度\(O(n\log n)\)。

code

#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int gi(){
int x=0,w=1;char ch=getchar();
while ((ch<'0'||ch>'9')&&ch!='-') ch=getchar();
if (ch=='-') w=0,ch=getchar();
while (ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
return w?x:-x;
}
const int N = 3e5+5;
int n,h[N],s1[N],t1,s2[N],t2,ins[N],cnt,mx[N<<2],tag[N<<2],c[N],ans;
long long sum;
struct node{
int y,x1,x2,op;
bool operator < (const node &b) const{
if (y==b.y) return op<b.op;
return y<b.y;
}
}p[N<<1];
int binary1(int x){
int l=1,r=t1,res=0;
while (l<=r){
int mid=l+r>>1;
if (h[s1[mid]]>h[x]) res=mid,r=mid-1;
else l=mid+1;
}
return s1[res];
}
int binary2(int x){
int l=1,r=t2,res=0;
while (l<=r){
int mid=l+r>>1;
if (h[s2[mid]]<h[x]) res=mid,r=mid-1;
else l=mid+1;
}
return s2[res];
}
void modify(int x,int l,int r,int ql,int qr,int v){
if (l>=ql&&r<=qr) {mx[x]+=v;tag[x]+=v;return;}
int mid=l+r>>1;
if (ql<=mid) modify(x<<1,l,mid,ql,qr,v);
if (qr>mid) modify(x<<1|1,mid+1,r,ql,qr,v);
mx[x]=max(mx[x<<1],mx[x<<1|1])+tag[x];
}
void mdf(int k){while(k<=n)++c[k],k+=k&-k;}
int qry(int k){int s=0;while(k)s+=c[k],k-=k&-k;return s;}
int main(){
n=gi();
for (int i=1;i<=n;++i) h[i]=gi();
for (int i=1;i<=n;++i) if (i==1||h[i]>h[s1[t1]]) s1[++t1]=i,ins[i]=1;
for (int i=n;i>=1;--i) if (i==n||h[i]<h[s2[t2]]) s2[++t2]=i,ins[i]=1;
for (int i=1;i<=n;++i){
if (ins[i]) continue;
int l=binary1(i),r=binary2(i);
if (l<i&&i<r){
p[++cnt]=(node){i+1,l,i-1,1};
p[++cnt]=(node){r+1,l,i-1,-1};
}
}
sort(p+1,p+cnt+1);
for (int i=1;i<=cnt;++i){
modify(1,1,n,p[i].x1,p[i].x2,p[i].op);
if (p[i].y!=p[i+1].y) ans=max(ans,mx[1]);
}
for (int i=n;i;--i) sum+=qry(h[i]-1),mdf(h[i]);
printf("%lld\n",sum-2*ans);
return 0;
}

[LOJ535]「LibreOJ Round #6」花火的更多相关文章

  1. loj #535. 「LibreOJ Round #6」花火 树状数组求逆序对+主席树二维数点+整体二分

    $ \color{#0066ff}{ 题目描述 }$ 「Hanabi, hanabi--」 一听说祭典上没有烟火,Karen 一脸沮丧. 「有的哦-- 虽然比不上大型烟花就是了.」 还好 Shinob ...

  2. 「LibreOJ Round #6」花火

    转化思维的好题! 链接:here 大致题意: 有$ n$个数字,你每次可以交换相邻两个,还有一次交换任意两个元素的机会,求最少的交换次数使得这些数字升序排序(原数列两两不同) $ solotion:$ ...

  3. loj #547. 「LibreOJ β Round #7」匹配字符串

    #547. 「LibreOJ β Round #7」匹配字符串   题目描述 对于一个 01 串(即由字符 0 和 1 组成的字符串)sss,我们称 sss 合法,当且仅当串 sss 的任意一个长度为 ...

  4. [LOJ#531]「LibreOJ β Round #5」游戏

    [LOJ#531]「LibreOJ β Round #5」游戏 试题描述 LCR 三分钟就解决了问题,她自信地输入了结果-- > -- 正在检查程序 -- > -- 检查通过,正在评估智商 ...

  5. [LOJ#530]「LibreOJ β Round #5」最小倍数

    [LOJ#530]「LibreOJ β Round #5」最小倍数 试题描述 第二天,LCR 终于启动了备份存储器,准备上传数据时,却没有找到熟悉的文件资源,取而代之的是而屏幕上显示的一段话: 您的文 ...

  6. [LOJ#516]「LibreOJ β Round #2」DP 一般看规律

    [LOJ#516]「LibreOJ β Round #2」DP 一般看规律 试题描述 给定一个长度为 \(n\) 的序列 \(a\),一共有 \(m\) 个操作. 每次操作的内容为:给定 \(x,y\ ...

  7. [LOJ#515]「LibreOJ β Round #2」贪心只能过样例

    [LOJ#515]「LibreOJ β Round #2」贪心只能过样例 试题描述 一共有 \(n\) 个数,第 \(i\) 个数 \(x_i\) 可以取 \([a_i , b_i]\) 中任意值. ...

  8. [LOJ#525]「LibreOJ β Round #4」多项式

    [LOJ#525]「LibreOJ β Round #4」多项式 试题描述 给定一个正整数 k,你需要寻找一个系数均为 0 到 k−1 之间的非零多项式 f(x),满足对于任意整数 x 均有 f(x) ...

  9. [LOJ#526]「LibreOJ β Round #4」子集

    [LOJ#526]「LibreOJ β Round #4」子集 试题描述 qmqmqm有一个长为 n 的数列 a1,a2,……,an,你需要选择集合{1,2,……,n}的一个子集,使得这个子集中任意两 ...

随机推荐

  1. Keras实践:模型可视化

    Keras实践:模型可视化 安装Graphviz 官方网址为:http://www.graphviz.org/.我使用的是mac系统,所以我分享一下我使用时遇到的坑. Mac安装时在终端中执行: br ...

  2. Git: A分支上的commit提交到B分支上

    1. 执行git log -3 --graph A,查看A分支下的commit: 注:commit 后面的hash值代表某个commit,这里把”82f1fb7138c5860cc775b4b5ea7 ...

  3. 用通俗的语言解释restful

    实现了REST规范的Web API就叫RESTful API. 简单来说:就是用url定位资源,用http描述来操作资源. web是什么:分布式信息系统为超文本文件和其他对象(资源)提供访问入口. 资 ...

  4. Linux 笔记 #04# Installing Tomcat 8 on Debian

    失败一 ※ 失败二  ※ 失败三 ※ 完 1- 确认机型: root@iZwz:~# lsb_release -a LSB Version: core-2.0-amd64:core-2.0-noarc ...

  5. c++第二十七天

    p135~p140:1.位运算符.作用于整数类型的运算对象,并把运算对象看成是二进制的集合,提供检查和设置二进制位的功能. 2.bitest:一种可表示任意大小的二进制位集合的标准库类型. 3.关于符 ...

  6. 用 Python 和 OpenCV 检测图片上的条形码(转载)

    原文地址:http://python.jobbole.com/80448/ 假设我们要检测下图中的条形码: # load the image and convert it to grayscale 1 ...

  7. 20155201 2016-2017-2《Java程序设计》课程总结

    20155201 2016-2017-2<Java程序设计>课程总结 目录 一.每周作业链接汇总 二.实验报告链接汇总 三.代码托管链接 四.课堂项目实践 五.课程收获与不足 六.问卷调查 ...

  8. IDEA类和方法注释模板设置

    在开发中使用idea的注释总结:由于IDEA自带的注释模板不是太好用,所以整理一下适用于自己的模板: 一.首先我们来设置IDEA中类的模板:(IDEA中在创建类时会自动给添加注释) 1.File--& ...

  9. 【联网】虚拟机下Linux(终端)配置网络的方法

    这几天在虚拟机vmware上部署centos系统,想通过内部联网用yum命令安装必需的软件,但是一直不能静态地址联网,今天终于找到一个方法centos内部设置IP,对外联网.设置过程如下: 1.首先是 ...

  10. Coursera SDN M1.2.1 SDN History: Programmable Networks 1

    接上第二点 NOTE (2)active networks => Programmability in networks(1990s) Sturcture: What are active ne ...