Cod sursa(job #2491615)

Utilizator Nemo123456nichita Nemo123456 Data 12 noiembrie 2019 20:48:44
Problema Datorii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.76 kb
#include <bits/stdc++.h>

using namespace std;

ifstream fin ("datorii.in");
ofstream fout ("datorii.out");

int v[15005], n, m;
long tazic(int x)
{
    long s = 0;
    for(int i = x; i >= 1; i -= i & -i)
        s += v[i];
    return s;
}
void schimbatazicul(int x, int y)
{
    for(int i = y; i <= n; i += i & -i)
        v[i] += x;
}
void citire()
{
    fin >> n >> m;
    for(int i = 1; i <= n; ++i)
    {
        int a;
        fin >> a;
        schimbatazicul(a, i);
    }
    for(int i = 1; i <= m; ++i)
    {
        int a, b, c;
        fin >> a >> b >> c;
        if(!a)
            schimbatazicul(-c, b);
        else
            fout << tazic(c) - tazic(b - 1) << '\n';
    }
}
int main()
{
    citire();
    return 0;
}