题目
在数组中的两个数字如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。
分析
看到这个题目,我们第一反应是顺序扫描整个数组。每扫描到一个数字的时候,逐个比较该数字和它后面的数字的大小。如果后面的数字比它小,则这两个数字就组成了一个逆序对。假设数组中含有 n 个数字。由于每个数字都要和O(n)个数字作比较,因此这个算法的时间复杂度是O(n^2)。
以数组 { 7,5,6,4 } 为例来分析统计逆序对的过程。每次扫描一个数字的时候,我们不能拿它和后面的每一个数字作比较,否则时间复杂度就是O(n^2),因此我们可以考虑先比较两个相邻的数字。
如图5.1(a)和5.1(b)所示,先把数组分解成两个长度为 2 的子数组,再把这两个子数组分别拆分成两个长度为 1 的数组。接下来一边合并相邻的子数组,一边统计逆序对的数目。在第一对长度为 1 的子数组 {7}、{5}中 7大于 5,因此(7,5)