Dynamic Range Sum Queries

Given an array of n integers, your task is to process q queries of the following types:

  1. update the value at position to u
  2. what is the sum of values in the range [a,b]?

Example:

Input: n = 8, q = 4, a = {3, 2, 4, 5, 1, 1, 5, 3}, queries = {{2, 1, 4}, {2, 5, 6}, {1, 3, 1}, {2, 1, 4}}

Output:

14 2 11

Approach:

C++

#include <bits/stdc++.h>
using namespace std;
long long arr[1000001];
long long tree[4010001];
void build(long long nodelong long startlong long end)
{
    if (start == end)
    {
        tree[node] = arr[start];
        return;
    }
    long long mid = (start + end) / 2;
    build(2 * nodestartmid);
    build(2 * node + 1mid + 1end);
    tree[node] = tree[2 * node] + tree[2 * node + 1];
}
long long query(long long nodelong long start,
                long long endlong long llong long r)
{
    if (r < start || l > end)
        return 0;
    if (l <= start && r >= end)
        return tree[node];
    long long mid = (start + end) / 2;
    long long p1 = query(2 * nodestartmidlr);
    long long p2 = query(2 * node + 1mid + 1endlr);
    return p1 + p2;
}
void update(long long nodelong long start,
            long long endlong long indexlong long val)
{
    if (start == end)
    {
        tree[node] = val;
        return;
    }
    int mid = (start + end) / 2;
    if (index <= mid)
        update(2 * nodestartmidindexval);
    else
    {
        update(2 * node + 1mid + 1endindexval);
    }
    tree[node] = tree[2 * node] + tree[2 * node + 1];
}
int main()
{
    long long n = 8q = 4;
    vector<inta = {32451153};

    vector<vector<long long>> queries = {{214},
                                         {256},
                                         {131},
                                         {214}};
    for (long long i = 1i <= ni++)
        arr[i] = a[i - 1];
    build(11n);
    for (long long i = 0i < qi++)
    {
        long long x = queries[i][0];
        long long l = queries[i][1];
        long long r = queries[i][2];

        if (x == 1)
        {
            arr[l] = r;
            update(11nlr);
        }
        else
            cout << query(11nlr<< "\n";
    }
    return 0;
}


No comments:

Post a Comment