Code:

#include<cstdio>
#include<algorithm>
#include<string>
#include<cstring>
using namespace std;
const int maxn=1000000+4;
int n,C[maxn];
struct Data_Structure{
int lowbit(int t){
return t&(-t);
}
void add(int pos,int delta){
while(pos<=n)C[pos]+=delta, pos+=lowbit(pos);
}
int query(int x){
int sum=0;
while(x>0){
sum+=C[x];
x-=lowbit(x);
}
return sum;
}
}T;
int A[maxn],position[maxn];
int main(){
scanf("%d",&n);
for(int i=1;i<=n;++i) scanf("%d",&A[i]), position[A[i]]=i;
long long last=0; for(int i=n;i>=1;--i){
last+=T.query(A[i] -1);
T.add(A[i],1);
} long long best=last; for(int i=1;i<=n;++i)
best=min(best,last-(position[i]-1) + (n-position[i])),last=last-(position[i]-1)+(n-position[i]);
printf("%lld",best);
return 0;
}

  

最新文章

  1. 优化SQLServer--表和索引的分区(二)
  2. SpringMVC基本使用
  3. HDU 2546
  4. bzoj1222: [HNOI2001]产品加工--DP
  5. Google File System翻译(转)
  6. 专门查看阻塞和死锁情况以及引起的SQL语句,你可以创建后,直接运行之。
  7. 【ZOJ】【3329】One Person Game
  8. centos 忘记 root 密码
  9. CodeForces 235C Cyclical Quest(后缀自动机)
  10. POJ 3468&lt;线段树,区间add&gt;
  11. efwplusUI框架,支持在Liunx服务器运行的Web开发框架,C#开发
  12. C#无限分级实现,前端WEB页面接收,后台提供层级Json数据
  13. Oleans集群之Consul再解释
  14. 又把JDK改回JDK1.8的过程
  15. [CEOI2008]order
  16. Linux系统下DHCP服务安装部署和使用详解
  17. [tool] AI视频翻译 解决英文视频字幕问题(类似youtube自动生成字幕)
  18. Windows下Oracle 11g安装以及创建数据库
  19. MySQL学习笔记Windows篇&lt;一&gt; Welcome to MySQL
  20. OpenCV 学习笔记 05 人脸检测和识别 AttributeError: module &#39;cv2&#39; has no attribute &#39;face&#39;

热门文章

  1. 学习supervisor
  2. idea报错:Please, configure Web Facet first!
  3. Android回炉系列之四大组件之首Activity
  4. PhotoZoom的工具栏 图片放大不失真
  5. Java通过UUID随机生成36位、32位唯一识别码(唯一字符串)
  6. Pyhton学习——Day59
  7. jQuery中的DatePicker今天按钮不起作用
  8. [USACO18OPEN] Multiplayer Moo (并查集+维护并查集技巧)
  9. oracle截取某一个字符之前或之后的值;substr();instr()
  10. RabbitMQ学习总结(4)——分发任务在多个工作者之间实例教程