题解 \(by\;zj\varphi\)

考虑如何才能最优。

每次一定把当前最小值移动到边界上,那么看它向左还是向右移更优。

用树状数组维护一下即可,复杂度 \(\mathcal O\rm (nlogn)\)

Code
#include<bits/stdc++.h>
#define ri register signed
#define p(i) ++i
namespace IO{
char buf[1<<21],*p1=buf,*p2=buf;
#define gc() p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?(-1):*p1++
struct nanfeng_stream{
template<typename T>inline nanfeng_stream &operator>>(T &x) {
ri f=1;x=0;register char ch=gc();
while(!isdigit(ch)) {if (ch=='-') f=0;ch=gc();}
while(isdigit(ch)) {x=(x<<1)+(x<<3)+(ch^48);ch=gc();}
return x=f?x:-x,*this;
}
}cin;
}
using IO::cin;
namespace nanfeng{
#define FI FILE *IN
#define FO FILE *OUT
template<typename T>inline T cmax(T x,T y) {return x>y?x:y;}
template<typename T>inline T cmin(T x,T y) {return x>y?y:x;}
typedef long long ll;
static const int N=1e5+7;
int *a[N],vis[N],num[N],l[N],r[N],mx,n;
ll ans;
struct BIT{
#define lowbit(x) ((x)&-(x))
int c[N];
inline void update(int x,int k) {for (ri i(x);i<=n;i+=lowbit(i)) c[i]+=k;}
inline int query(int x) {
int res(0);
for (ri i(x);i;i-=lowbit(i)) res+=c[i];
return res;
}
}B;
inline int main() {
//FI=freopen("nanfeng.in","r",stdin);
//FO=freopen("nanfeng.out","w",stdout);
cin >> n;
for (ri i(1);i<=n;p(i)) cin >> num[i],p(vis[num[i]]),mx=cmax(mx,num[i]);
for (ri i(1);i<=mx;p(i)) {
if (!vis[i]) continue;
a[i]=new int[vis[i]+1];
l[i]=1;
}
for (ri i(1);i<=n;p(i)) a[num[i]][p(r[num[i]])]=i,B.update(i,1);
for (ri i(1);i<=mx;p(i)) {
if (!vis[i]) continue;
while(l[i]<=r[i]) {
int x1=a[i][l[i]],x2=a[i][r[i]];
int d1=B.query(x1-1),d2=B.query(n)-B.query(x2);
if (d1<d2) {
ans+=d1;
B.update(x1,-1);
p(l[i]);
} else {
ans+=d2;
B.update(x2,-1);
--r[i];
}
//printf("ans=%lld\n",ans);
}
}
printf("%lld\n",ans);
return 0;
}
}
int main() {return nanfeng::main();}

最新文章

  1. mysql常见错误及解决方案
  2. JS定义函数的两种方式:函数声明和函数表达式
  3. [C#.NET]
  4. MySql数据源配置
  5. Windows环境下Android Studio v1.0安装教程
  6. 为网页设计师准备的30个使用的HTML5框架
  7. HTML 5中的文件处理之FileAPI(转载)
  8. CALayer 为什么选择 cg 开头 而 不选择 UI 开头
  9. 第八篇:python高级之多进程
  10. 自己改写了一个图片局部放大的jquery插件页面里面的html代码少了,同一个页面可以调用多个
  11. ASP.NET Core Authorization
  12. 飞信免费邮件api,飞信界面
  13. html5权威指南:用元数据元素说明文档
  14. Hello,Kubernetes
  15. 如何用jQuery实现div随鼠标移动而移动(详解)?----2017-05-12
  16. 俄罗斯方块(2D、3D)
  17. OpenCV + Python 人脸检测
  18. Nginx详解七:Nginx基础篇之Nginx官方模块
  19. Mongodb: Sort operation used more than the maximum 33554432 bytes of RAM
  20. mybatis-plus代码生成器

热门文章

  1. Vue3 + TypeScript 开发实践总结
  2. mysql中函数cast使用
  3. Java003-String字符串
  4. MongoDB 基础学习
  5. 前端小技巧:css sprite----V客学院技术分享
  6. 全站 HTTPS 就一定安全了吗?
  7. 关键字替代符号C++
  8. python的web框架知识点
  9. Linux[Manjaro] 小新15笔记本AMD ryzen锐龙4800U,在安装系统后出现的随即死机冻屏问题
  10. Java流程控制05——循环结构