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

数组中的逆序对

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

public class Solution {
    
    private int re = 0;
    
    public int InversePairs(int [] array) {
        merge(array,0,array.length-1);
        return re;
    }
    
    public void merge(int[] array,int s,int e){
        if(s>=e){
            return;
        }
        int c = (s+e)>>1;
        merge(array,s,c);
        merge(array,c+1,e);
        int[] temp = new int[e-s+1];
        int i = 0;
        int r = c+1;
        int t = s;
        while(s<=c && r<=e){
            if(array[s]<=array[r]){
                temp[i++] = array[s++];
            }else{
                re = (re + c - s + 1)%1000000007;
                temp[i++] = array[r++];
            }
        }
        while(s<=c){
            temp[i++] = array[s++];
        }
        while(r<=e){
            temp[i++] = array[r++];
        }
        for (int value : temp) {
            array[t++] = value;
        }
    }
}
全部评论

相关推荐

01-02 21:17
已编辑
西安理工大学 后端
程序员小白条:项目不太重要,你的优势的算法竞赛,然后多背相关的八股文,项目可以不作为重点考虑,面试可能就简单带过项目就行了,你可以直接写简历,背项目相关的八股文就行,也不用自己做,时间紧张的情况下,性价比最高
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务