6.19刷题打卡

题目 数组中的逆序对

最爱的树状数组

    int mod = (int) 1e9 + 7;
    public int InversePairs (int[] nums) {
        // write code here
        int[] a = nums.clone();
        Arrays.sort(a);
        int n = a.length;
        int[] t = new int[n + 1];
        long ans = 0;
        for (int v: nums) {
            int l = 0, r = n - 1;
            while (l <= r) {
                int m = l + r >> 1;
                if (a[m] < v) l = m + 1;
                else r = m - 1;
            }
            l = n - l; // 0 ~ n - 1 -> 1 ~ n
            ans = (ans + find(t, l)) % mod;
            add(t, l);
        }
        return (int) ans;
    }
    void add(int[] t, int i) {
        while (i < t.length) {
            t[i]++;
            i += i & -i;
        }
    }
    long find(int[] t, int i) {
        long ans = 0;
        while (i > 0) {
            ans += t[i];
            i -= i & -i;
        }
        return ans;
    }

打卡截图

#和牛牛一起刷题打卡#
全部评论

相关推荐

震撼沃玛一整年:查看图片
点赞 评论 收藏
分享
Cherrycola01:0实习 0项目 约等于啥也没有啊 哥们儿这简历认真的吗
点赞 评论 收藏
分享
笑死&nbsp;不是哥们离校了我真要睡街了&nbsp;加上还有几w的贷款&nbsp;不接受我准备去当三和大神
梦想是成为七海千秋:没事,hr这下就有底气了,下次遇到一个不接受的就说,你看,人家这学历都接受了,你凭什么不接受
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

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