LeetCode/数组中的逆序对

打印 上一主题 下一主题

主题 860|帖子 860|积分 2584

在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。
最简单的思路就是二重循环暴力匹配
更优的方法是通过归并递归,先拆分成子问题,先计算区间内的逆序数,然后归并,同时计算区间之间的逆序数,并把总数加起来
计算两区间之间的逆序对时,可以跟合并区间操作统一起来,在归并合并区间时,我们使用了两个指针记录两区间初始位置
相互比较大小,复制给辅助数组,并轮流前进,以从前往后的方向为例,当右指针指向数小于左指针,那么它也必然小于左指针之后的数
直接计算得到了这个数相对左区间的逆序对,这是就利用了归并区间内有序的性质和区间相对位置确定的性质
[code]class Solution {public:    int reversePairs(vector& nums) {        vector tmp(nums.size());        return mergeSort(0, nums.size() - 1, nums, tmp);//归并排序    }private:    int mergeSort(int l, int r, vector& nums, vector& tmp) {        // 终止条件        if (l >= r) return 0;//逆序数返回0        // 递归划分        int m = (l + r) / 2;        int res = mergeSort(l, m, nums, tmp) + mergeSort(m + 1, r, nums, tmp);//计算各自区间内的逆序对并排序        // 合并阶段,计算两区间之间的逆序对        int i = l, j = m + 1;//记录左右区间首指针        for (int k = l; k
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

王國慶

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表