链接:http://poj.org/problem?id=2299

题意:给出n个数,求将这n个数从小到大排序,求使用快排的需要交换的次数。

分析:由快排的性质很容易发现,只需要求每个数的逆序数累加起来就行了。逆序数可以用树状数组求。

n<500000,0<=a[i]<=999,999,999,很明显数组不可能开这么大,所以需要离散化。

可以用一个结构体

struct node{
    int val,pos;
}a[N];

pos表示每个数的下标,val表示该数的值

按val从小到大排序,然后b[a[i].pos]]=i,就实现了离散化,保证了原来序列的大小关系不变。

之后就是简单的树状数组求逆序数了。

AC代码如下:

 #include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=;
#define LL __int64
int c[N],b[N],n;
struct node{
int val,pos;
bool operator <(const node &a)const{
return val<a.val;
}
}a[N];
int lowbit(int x)
{
return x&(-x);
}
void update(int x,int num)
{
while(x<=N)
{
c[x]+=num;
x+=lowbit(x);
}
}
LL sum(int x)
{
LL s=;
while(x>)
{
s+=c[x];
x-=lowbit(x);
}
return s;
}
int main()
{
int i;
while(scanf("%d",&n)&&n)
{
for(i=;i<=n;i++)
{
scanf("%d",&a[i].val);
a[i].pos=i;
}
sort(a+,a+n+);
for(i=;i<=n;i++)
b[a[i].pos]=i;
memset(c,,sizeof(c));
LL ans=;
for(i=;i<=n;i++)
{
update(b[i],);
ans+=i-sum(b[i]);
}
printf("%I64d\n",ans);
}
return ;
}

最新文章

  1. 简单爬虫,突破IP访问限制和复杂验证码,小总结
  2. TortoiseGit 相关操作
  3. kafka 订单应用需求
  4. Autofac.Integration.Mvc.Owin分析
  5. C# vba 操作 Word
  6. 将自己写的Python代码打包放到PyPI上
  7. OpenNMS在安装”我找不到jrrd.dll“错误的解决方法
  8. html5权威指南:html全局属性
  9. arguments及arguments.callee
  10. js根据年月得到当前这个月总共有多少天
  11. Html5 标签三(图片)
  12. Java调用Elasticsearch API查询及matchPhraseQuery和matchQuery的区别
  13. [转]TOMCAT启动提示NB: JAVA_HOME should point to a JDK not a JRE解决
  14. 用Qemu模拟vexpress-a9 (一) --- 搭建Linux kernel调试环境【转】
  15. 第六章:加载或保存JSON数据
  16. Android 图片压缩器
  17. 设置PYTHONIOENCODING
  18. 【BZOJ4675】点对游戏 树分治+期望
  19. AIX PowerHA (HACMP) Commands
  20. Spark的job调优(1)

热门文章

  1. Gitlab+Jenkins学习之路(一)之Git基础
  2. 用C实现单隐层神经网络的训练和预测(手写BP算法)
  3. java面试资源(面试题、面试经验等)
  4. $(&#39;#uplodFileForm&#39;)[0].submit();
  5. senlenium使用
  6. RenderSprite小记
  7. OpenFastPath(2):原生态Linux Socket应用如何移植到OpenFastPath上?
  8. Tomcat之初识初体验
  9. python基础_字符编码
  10. DWR、Comet4j在Nginx+Tomcat组合下的优化