http://acm.hust.edu.cn/vjudge/problem/15764

http://blog.csdn.net/libin56842/article/details/8531117

逆序数的概念:

在一个排列中,如果一对数的前后位置与大小顺序相反,即前面的数大于后面的数,那么它们就称为一个逆序。一个排列中逆序的总数就称为这个排列的逆序数。逆序数为偶数的排列称为偶排列;逆序数为奇数的排列称为奇排列。如2431中,21,43,41,31是逆序,逆序数是4,为偶排列。
也是就说,对于n个不同的元素,先规定各元素之间有一个标准次序(例如n个 不同的自然数,可规定从小到大为标准次序),于是在这n个元素的任一排列中,当某两个元素的先后次序与标准次序不同时,就说有1个逆序。一个排列中所有逆序总数叫做这个排列的逆序数。
 
而一个排列的逆序树,可以通过这个方法求得:
在输入排列每个数时,找之前比它大的数字有多少个,然后插入线段树,最后加起来的结果就是总的逆序数
 
对于将最后一个数插到最前面,可以通过循环计算求得
 
  1. #include <iostream>
  2. #include <string>
  3. #include <cstring>
  4. #include <cstdlib>
  5. #include <cstdio>
  6. #include <cmath>
  7. #include <algorithm>
  8. #include <stack>
  9. #include <queue>
  10. #include <cctype>
  11. #include <vector>
  12. #include <iterator>
  13. #include <set>
  14. #include <map>
  15. #include <sstream>
  16. using namespace std;
  17.  
  18. #define mem(a,b) memset(a,b,sizeof(a))
  19. #define pf printf
  20. #define sf scanf
  21. #define spf sprintf
  22. #define pb push_back
  23. #define debug printf("!\n")
  24. #define MAXN 5000 + 5
  25. #define MAX(a,b) a>b?a:b
  26. #define blank pf("\n")
  27. #define LL long long
  28. #define ALL(x) x.begin(),x.end()
  29. #define INS(x) inserter(x,x.begin())
  30. #define pqueue priority_queue
  31. #define INF 0x3f3f3f3f
  32.  
  33. struct node
  34. {
  35. int l,r,c;
  36. }T[MAXN*];
  37.  
  38. void PushUp(int rt)
  39. {
  40. T[rt].c = T[rt<<].c + T[(rt<<)+].c;
  41. }
  42.  
  43. void build(int l,int r,int x)
  44. {
  45. T[x].l = l;
  46. T[x].r = r;
  47. T[x].c = ;
  48. if (l == r) return;
  49. int mid = (l+r)>>;
  50. build(l,mid,x<<);
  51. build(mid+,r,(x<<) + );
  52. }
  53.  
  54. void update(int l,int x)
  55. {
  56. if(T[x].l == T[x].r && T[x].l == l)
  57. {
  58. T[x].c++;
  59. return;
  60. }
  61. int mid = (T[x].l + T[x].r)>>;
  62. if (l > mid)
  63. {
  64. update(l,(x<<) + );
  65. }
  66. else
  67. {
  68. update(l,x<<);
  69. }
  70. PushUp(x);
  71. }
  72.  
  73. int n,m,ans;
  74.  
  75. void query(int l,int r,int x)
  76. {
  77. if(T[x].l == l && T[x].r == r)
  78. {
  79. ans += T[x].c;
  80. return;
  81. }
  82. int mid = (T[x].l + T[x].r)>>;
  83. if (l > mid)
  84. {
  85. query(l,r,(x<<)+);
  86. }
  87. else if(r<=mid)
  88. {
  89. query(l,r,(x<<));
  90. }
  91. else
  92. {
  93. query(l,mid,(x<<));
  94. query(mid+,r,(x<<)+);
  95. }
  96. }
  97.  
  98. int a[MAXN];
  99.  
  100. int main()
  101. {
  102. int t,i,kase=;
  103. while(sf("%d",&n)==)
  104. {
  105. build(,n,);
  106. int sum = ;
  107. for(i=;i<n;i++)
  108. {
  109. sf("%d",&a[i]);
  110. a[i]++;
  111. ans = ;
  112. if(a[i]!=n) query(a[i]+,n,);
  113. sum+=ans;
  114. update(a[i],);
  115. }
  116. int result = sum;
  117. for(i=n-;i>=;i--)
  118. {
  119. sum = sum - (n - a[i]) + a[i] -;
  120. result = min(result,sum);
  121. }
  122. pf("%d\n",result);
  123. }
  124. return ;
  125. }

hdu 1394 逆序数(线段树)的更多相关文章

  1. HDU 1394 逆序数 线段树单点跟新 | 暴力

    Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  2. HDU 1394 Minimum Inversion Number(最小逆序数 线段树)

    Minimum Inversion Number [题目链接]Minimum Inversion Number [题目类型]最小逆序数 线段树 &题意: 求一个数列经过n次变换得到的数列其中的 ...

  3. HDU 1394 (逆序数) Minimum Inversion Number

    原来求逆序数还可以用线段树,涨姿势了. 首先求出原始序列的逆序数,然后递推每一个序列的逆序数. #include <cstdio> #include <cstring> #in ...

  4. 51Nod 1019 逆序数(线段树)

    题目链接:逆序数 模板题. #include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i(a) ...

  5. POJ 2299 Ultra-QuickSort 求逆序数 线段树或树状数组 离散化

    我用的线段树写的. num数组表示已插入的数值的个数. 由于a[i]数值很大,但是n不是很大,所以要离散化处理 9 1 0 5 4 离散化后 4 1 0 3 2 这样保证最大值不会超过n #inclu ...

  6. hdu 5700区间交(线段树)

    区间交 Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...

  7. Snacks HDU 5692 dfs序列+线段树

    Snacks HDU 5692 dfs序列+线段树 题意 百度科技园内有n个零食机,零食机之间通过n−1条路相互连通.每个零食机都有一个值v,表示为小度熊提供零食的价值. 由于零食被频繁的消耗和补充, ...

  8. HDU 1394 Minimum Inversion Number (树状数组 && 规律 && 逆序数)

    题意 : 有一个n个数的数列且元素都是0~n-1,问你将数列的其中某一个数及其前面的数全部置到后面这种操作中(比如3 2 1 0中选择第二个数倒置就产生1 0 3 2)能产生的最少的逆序数对是多少? ...

  9. HDU 1394 Minimum Inversion Number (树状数组求逆序对)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1394 题目让你求一个数组,这个数组可以不断把最前面的元素移到最后,让你求其中某个数组中的逆序对最小是多 ...

随机推荐

  1. 虚拟机网络配置,桥接模式和NAT模式

    虚拟机网络设置方式的研究: 主要就是桥接网络,和NAT模式: 桥接网络:桥接网络中,相当于虚拟机的网卡和主机的物理网卡均连接到虚拟机软件提供的VMnet0虚拟交换机上,因此虚拟机和主机是平等的,相当于 ...

  2. Python3之Memcache使用

    简介 Memcached是一个高性能的分布式内存对象缓存系统,用于动态WEB应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态,数据库网站的速度.Memcached ...

  3. SDUT OJ 图结构练习——最短路径 ( Floyed 算法 AND Dijkstra算法)

    图结构练习——最短路径 Time Limit: 1000 ms            Memory Limit: 65536 KiB Submit Statistic Discuss Problem ...

  4. sqlserver 临时表,多用户同时访问冲突吗?

      当然不会冲突,一个井号的临时表(本地临时表),在数据库中物理表名并非你看到的,而是系统会为你的临时表生成一个唯一的表名,所以其它用户使用和建同样的表不会发生冲突.

  5. sharding-jdbc数据分片配置

    数据分片 不使用Spring 引入Maven依赖 <dependency> <groupId>org.apache.shardingsphere</groupId> ...

  6. jquery实现淘宝动态图展示商品

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  7. 递归缓存技术,缓存机制Memoization

    先看一下代码: 再看一下执行时间: 可以看出第一个阶乘的执行时间是3ms,后面的由于缓存了之前的计算结果,所以直接返回结果. 原理就是缓存之前的计算,避免重复计算.关键在于建立缓存数组. 可以看一下执 ...

  8. Miller_Rabin素数测试【学习笔记】

    引语:在数论中,对于素数的研究一直就很多,素数测试的方法也是非常多,如埃式筛法,6N±1法,或者直接暴力判(试除法).但是如果要判断比较大的数是否为素数,那么传统的试除法和筛法都不再适用.所以我们需要 ...

  9. no git binary found in $path(已解决,但是还有疑问)

    跟同行研究个项目代码,他把代码打包发我后,我解压到本地,路径和我本地个人项目路径基本相同, 但是当执行npm install时,就报了 no git binary found in $path ,这个 ...

  10. Emit生成特定接口的类

    参考 动态生成类 http://www w2bc com/Article/44799 http://www.cnblogs.com/yingql/archive/2009/03/24/1420914. ...