Cod sursa(job #2679366)

Utilizator KPP17Popescu Paul KPP17 Data 30 noiembrie 2020 14:26:37
Problema Datorii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.47 kb
#include <fstream>
#define fisier "datorii"
std::ifstream in(fisier ".in");
std::ofstream out(fisier ".out");
int V[20002];
int S(int i) {return i? V[i] + S(i^i&-i): 0;}
int main()
{
    int n, m; in >> n >> m;
    for (int i = 1; i <= n; i++)
        {int e; in >> e; V[i+(i&-i)] += V[i] += e;}
    while (m--)
    {
        bool v; int a, b; in >> v >> a >> b;
        if (v) out << S(b) - S(a-1) << '\n';
        else for (; a <= n; a += a&-a) V[a] -= b;
    }
}