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

数组中的逆序对

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;
    }
};
全部评论

相关推荐

找到实习了&nbsp;给了150一天&nbsp;但是说是低代码&nbsp;值得去吗
码农索隆:是在没实习,可去,待个一两周,不行就润呗
点赞 评论 收藏
分享
那一天的Java_J...:他本来公司就是做这个的,不就是正常的游戏客户端和服务器开发,软硬件联动,有啥恶心不恶心的,提前告诉你就是怕你接受不了,接受不了就没必要再往后走流程浪费时间,虽然这公司是一坨。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务