lojround6
花团
线段树分治裸题
给出了结束时间跟离线没区别
「LibreOJ Round #6」花火
首先在第一次使用交换是显然的
然后统计逆序对暴力是n^2的(前缀和优化)
因为交换两个点改变的只有x<i y>i
刚开始想了决策是不是单调的
然后发现不是的
我们可以将它放在图上
然后我们会发现只有左上角没有东西,右下角没有东西的点才有用
然后我们会发现这个东西满足决策单调性(很容易证明分别取两个点看一看矩形的变化就行了)
然后就是比较套路的我们要用分治算法来解决
题解用的是树状数组,也就是每层跑一次(就是bfs)
因为理论复杂度差不多然后主席树没细节就写了主席树,跑的好像挺快的啊?
时间复杂度nlog^2
#include <bits/stdc++.h>
using namespace std;
#define rint register int
#define IL inline
#define rep(i,h,t) for (rint i=h;i<=t;i++)
#define dep(i,t,h) for (rint i=t;i>=h;i--)
#define me(x) memset(x,0,sizeof(x))
#define lowbit(x) (x&(-x))
#define ll long long
const int N=4e5;
const int N2=N*;
int a[N],sum,ans,root[N],cnt,n;
#define mid ((h+t)>>1)
struct sgt{
int data[N2],ls[N2],rs[N2];
void insert(rint &x,rint lst,rint h,rint t,rint pos)
{
x=++cnt; ls[x]=ls[lst]; rs[x]=rs[lst];
data[x]=data[lst]+;
if (h==t) return;
if (pos<=mid) insert(ls[x],ls[lst],h,mid,pos);
if (pos>mid) insert(rs[x],rs[lst],mid+,t,pos);
}
int find(rint x,rint h,rint t,rint h1,rint t1)
{
if (!x) return ;
if (h1<=h&&t<=t1) return(data[x]);
rint ans=;
if (h1<=mid) ans+=find(ls[x],h,mid,h1,t1);
if (mid<t1) ans+=find(rs[x],mid+,t,h1,t1);
return ans;
}
IL int query(int x,int y,int h,int t)
{
if (x>y) return();
return(find(root[y],,n,h,t)-find(root[x-],,n,h,t));
}
}B;
int s1[N],s2[N];
void fz(int h,int t,int h1,int t1)
{
int num=-1e9,num2=;
rep(i,h1,t1)
if (s2[i]>=s1[mid])
{
rint t1=s1[mid],t2=s2[i];
rint ans2=;
if (a[t2]<a[t1])
{
// ans1=B.query(t1,t2,a[t2]+1)+t2-t1-B.query(t1,t2,a[t1]);
ans2=*B.query(t1,t2,a[t2]+,a[t1]-)+;
// ans2=t2-t1;
// ans2=2*(ans1-ans2)+1;
if (ans2>=num) num=ans2,num2=i;
}
}
sum=max(sum,num);
if (!num2) num2=h1;
if (h<=mid-) fz(h,mid-,h1,num2);
if (mid+<=t) fz(mid+,t,num2,t1);
}
int main()
{
freopen("1.in","r",stdin);
freopen("1.out","w",stdout);
ios::sync_with_stdio(false);
cin>>n;
rep(i,,n) cin>>a[i];
ll ans=;
rep(i,,n)
{
ans+=B.query(,i-,a[i]+,n);
B.insert(root[i],root[i-],,n,a[i]);
}
int cnt1=,cnt2=;
rep(i,,n) if (a[i]>=a[s1[cnt1]]) s1[++cnt1]=i;
a[]=1e9;
dep(i,n,) if (a[i]<=a[s2[cnt2]]) s2[++cnt2]=i;
reverse(s2+,s2+cnt2+);
fz(,cnt1,,cnt2);
cout<<min(ans,ans-sum+)<<endl;
return ;
}
lojround6的更多相关文章
随机推荐
- boost::asio实现一个echo服务器
以前使用ACE实现Server框架,但是觉得太笨重,决定采用boost.asio来写服务器程序: 1.服务器构建在linux上面:当然也可以在windows下运行 2.io部分采用非阻塞模式.业务逻辑 ...
- FreeSWITCH异常原因总结
最经在玩FreeSWITCH的时候,遇到很多的问题,特此总结一下,希望以后不要犯类似的错误了: 1.Client端无法注册,但是FS运行正常? 解决办法:查看防火墙是否关闭./etc/init.d/i ...
- Django 配置(一)开启服务
注:这里使用的是命令行创建,当然也可以用 pycharm 自带的 django 项目创建更加简便. 安装django pip install django 创建项目 django-admin star ...
- 自定义redis连接池(字典操作)
pool=redis.ConnectionPool(host='127.0.0.1', port=6379,max_connections=1000)conn=redis.Redis(connecti ...
- kindeditor用法简单介绍(转)
1,首先去官网下载http://www.kindsoft.net/ 2,解压之后如图所示: 由于本人做的是用的是JSP,所以ASP,PHP什么的就用不上了,直接把那些去掉然后将整个文件夹扔进Myecl ...
- C#将DLL嵌入到exe当中
1.选中项目文件,找到Resources.resx,双击Resources.resx,然后添加文件(选择需要的dll文件),点击确定,项目下会自动生成一个Resources文件夹,里面包含添加dll. ...
- Confluence 6 用户目录图例 - 连接 Jira
上面的图:Confluence 连接到 JIRA 为用户管理. https://www.cwiki.us/display/CONFLUENCEWIKI/Diagrams+of+Possible+Con ...
- D3.js 添加zoom缩放功能后dblclick双击也会放大的问题
svg.call(zoom).on("dblclick.zoom", null); https://stackoverflow.com/questions/25007466/d3- ...
- html 之表单,div标签等。。。。。。。
一.表单 功能:表单用于向服务器传输数据,从而实现用户与Web服务器的交互 表单能够包含input系列标签,比如文本字段.复选框.单选框.提交按钮等等. 表单还可以包含textarea.select. ...
- 【层次聚类】python scipy实现
层次聚类 原理 有一个讲得很清楚的博客:博客地址 主要用于:没有groundtruth,且不知道要分几类的情况 用scipy模块实现聚类 参考函数说明: pdist squareform linkag ...