题解 | #数组中的逆序对#

数组中的逆序对

http://www.nowcoder.com/practice/96bd6684e04a44eb80e6a68efc0ec6c5

class Solution {
public:
    void merge_sort(vector<int>& vec, int l, int r, int& res) {
        if(l >= r)
            return;
        int mid = (l + r) / 2;
        merge_sort(vec, l, mid, res);
        merge_sort(vec, mid + 1, r, res);
        int i = l, j = mid + 1, k = 0;
        vector<int> temp(r-l+1);
        while(i <= mid && j <= r) {
            if(vec[i] <= vec[j]) {
                temp[k++] = vec[i++];
            }else {
                res += (mid - i + 1);
                res = res % 1000000007;
                temp[k++] = vec[j++];
            }
        }
        while(i <= mid) {
            temp[k++] = vec[i++];
        }
        while(j <= r) {
            temp[k++] = vec[j++];
        }
        i = l, k = 0;
        while(l <= r) {
            vec[l++] = temp[k++];
        }
        return;
    }
    int InversePairs(vector<int> data) {
        int res = 0;
        int n = data.size();
        if( n < 2)
            return res;
        merge_sort(data, 0, n - 1, res);
        return res;
    }
};
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-27 10:52
点赞 评论 收藏
分享
我见java多妩媚:大外包
点赞 评论 收藏
分享
offer多多的六边形战士很无语:看了你的博客,感觉挺不错的,可以把你的访问量和粉丝数在简历里提一下,闪光点(仅个人意见)
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-26 16:06
已编辑
快手电商 后端 23k-35k
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务