小红统计区间(hard) - 树状数组 + 离散化

题面

分析

存在负数不满足单调性,因此无法二分或者双指针,对于每一段符合条件的区间 [ l , r ] [l, r] [l,r] 都有 s u m [ r ] − s u m [ l − 1 ] > = k sum[r] - sum[l - 1] >= k sum[r]−sum[l−1]>=k ,也就是 s u m [ l − 1 ] < = s u m [ r ] − k sum[l - 1] <= sum[r] - k sum[l−1]<=sum[r]−k ,那么如果对于所有区间的前缀和来进行顺序存储,那么对于当前前缀和 s u m [ i ] sum[i] sum[i] ,可以去找小于等于 s u m [ i ] − k sum[i] - k sum[i]−k 的符合条件的前缀和有多少,但是前缀和的范围很大,所以就要进行离散化,将所有需要用到的前缀和都进行i离散化重新定下标,然后可以通过树状数组每次对遍历到的前缀和的位置加一,统计可以加上树状数组查询 s u m [ i ] − k sum[i] - k sum[i]−k 的结果,也就是这之前有多少个满足条件的前缀和。

代码
cpp 复制代码
#include <bits/stdc++.h>

using namespace std;
using ll = long long;

const int N = 2e5 + 10;

ll a[N];
int tr[N];
map<ll, int> m;

void add(int u) {
    for(int i = u; i < N; i += (i & -i)) {
        tr[i] ++;
    }
    return ;
}

int query(int x) {
    int ans = 0;
    for(int i = x; i >= 1; i -= i & -i) ans += tr[i];
    return ans;
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    
    int n;
    ll k;
    cin >> n >> k;
    for(int i = 1; i <= n; i ++) {
        cin >> a[i];
        a[i] += a[i - 1];
    }
    m[0] = 1;
    for(int i = 1; i <= n; i ++) {
        m[a[i]] = 1;
        m[a[i] - k] = 1;
    }
    int now = 1;
    for(auto &x: m) {
        x.second = now ++;
    }
    //for(auto j: m) cout <<j.first << ' ' <<  j.second << endl;
    ll ans = 0;
    add(m[0]);
    for(int i = 1; i <= n; i ++) {
        ans += query(m[a[i] - k]);
        add(m[a[i]]);
    }
    cout << ans << "\n";
}
相关推荐
小雅痞15 小时前
[Java][Leetcode middle] 167. 两数之和 II - 输入有序数组
java·算法·leetcode
CN-Dust15 小时前
【C++】输入cin例题专题
java·c++·算法
数模竞赛Paid answer16 小时前
2025年MathorCup数学建模A题汽车风阻预测解题文档与程序
算法·数学建模·mathorcup
Old Uncle Tom1 天前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆1 天前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移1 天前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业1 天前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业1 天前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5481 天前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove1 天前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归