码迷,mamicode.com
首页 > 编程语言 > 详细

数组中的逆序对

时间:2016-04-13 13:16:17      阅读:217      评论:0      收藏:0      [点我收藏+]

标签:

 重新复制的数组应该在每次合并后都更新,剑指offer好像没有做。

class Solution {
public:
    int find(vector<int>&data,int begin,int end,vector<int> &res)
        {
        if(begin==end)
            return 0;
        int mid=(begin+end)/2;
        int left=find(data,begin,mid,res);
        int right=find(data,mid+1,end,res);
        int i=mid,j=end,num=0,k=end;
        while(i>=begin&&j>=mid+1)
            {
            while(i>=begin&&data[i]>data[j])
                {
                res[k--]=data[i--];
                num+=j-mid;
            }
                res[k--]=data[j--];
        }
        while(i>=begin)
           res[k--]=data[i--];
        while(j>=mid+1)
            res[k--]=data[j--];
        for(int i=0;i<data.size();i++)
            data[i]=res[i];
        return left+right+num;
    }
    int InversePairs(vector<int> data) {
        if(data.size()<2)return 0;
        vector<int> res(data.size(),0);
        for(int i=0;i<data.size();i++)
            res[i]=data[i];
        return find(data,0,data.size()-1,res);
    }
};

 

数组中的逆序对

标签:

原文地址:http://www.cnblogs.com/daocaorenblog/p/5386653.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!