1688 求逆序对

简介: 题目描述 Description给定一个序列a1,a2,…,an,如果存在iaj,那么我们称之为逆序对,求逆序对的数目数据范围:N
题目描述 Description

给定一个序列a1,a2,…,an,如果存在i<j并且ai>aj,那么我们称之为逆序对,求逆序对的数目

数据范围:N<=105。Ai<=105。时间限制为1s。

输入描述 Input Description

第一行为n,表示序列长度,接下来的n行,第i+1行表示序列中的第i个数。

输出描述 Output Description

所有逆序对总数.

样例输入 Sample Input

4

3

2

3

2

样例输出 Sample Output

3

分析:这个是对归并排序的典型应用

 1 #include<stdio.h>
 2 
 3 int n,a[1000100],t[1000010];
 4 long long ans=0;
 5 
 6 void merge_sort(int A[],int l,int r,int T[])
 7 {
 8     if(l<r)
 9     {
10         int m=l+((r-l)>>1);
11         int x=l,y=m+1,i=l;
12         merge_sort(A,l,m,T);
13         merge_sort(A,m+1,r,T);
14         while(x<=m||y<=r)
15         {
16             if(y>r || (x<=m && A[x] <= A[y])) T[i++]=A[x++];
17             else {T[i++]=A[y++];ans+=(m-x+1);}
18         }
19         for(i=l;i<=r;i++) A[i]=T[i];
20     }
21 }
22 
23 
24 int main()
25 {
26     
27     scanf("%d",&n);
28     for(int i=1;i<=n;i++) scanf("%d",&a[i]);
29     merge_sort(a,1,n,t);
30     printf("%lld\n",ans);
31     return 0;
32 }

 

 

相关文章
|
C++
剑指offer 53. 数组中的逆序对
剑指offer 53. 数组中的逆序对
77 0
剑指offer 53. 数组中的逆序对
|
人工智能
1311:【例2.5】求逆序对
1311:【例2.5】求逆序对
130 0
|
算法 C语言 C++
【双指针问题】977. 有序数组的平方
给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。
53 0
|
算法 C语言 C++
【二分查找】1201. 丑数 III
二分查找是一种高效的查找算法,其时间复杂度为 O(log n)。在许多情况下,我们需要在一个有序数组中找到某个目标值的搜索范围。本文将介绍一种基于二分查找的搜索范围查找算法,该算法能够快速找到目标值在数组中的起始和结束位置。
69 0
解 旋转数组
解 旋转数组
逆序对问题
逆序对问题
71 0
最大子数组
最大子数组
70 0
【LeetCode】第4天 - 977. 有序数组的平方 | 189. 旋转数组
【LeetCode】第4天 - 977. 有序数组的平方 | 189. 旋转数组
99 0
【LeetCode】第4天 - 977. 有序数组的平方 | 189. 旋转数组
|
人工智能
K个逆序对数组
K个逆序对数组