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;
    }

打卡截图

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

相关推荐

珩珺:那些经历都太大太空了,实习的情况不了解,大创项目连名字、背景、目的及意义都没体现出来;地摊经济更是看完连卖的什么产品都不知道,项目成果直接写营收多少都更直观真实一点;后面那个校文体部的更是工作内容是组织活动整理流程,成果变成了当志愿者,而且你们学校本科学生会大一入学就直接当部长吗,志愿里面还提到了疫情防控,全面解封是22年12月的事情,可能时间上也有冲突。可能你花了钱人家就用AI给你随便写了点内容改了一下,没什么体现个性化的点
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

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