Cod sursa(job #2775026)

Utilizator ValiAntonieAntonie Valentin ValiAntonie Data 14 septembrie 2021 01:24:13
Problema Arbori de intervale Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.37 kb
#include <bits/stdc++.h>

using namespace std;

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

int i,n,x,v[100005],a[500000],m,p,b,c;

void build(int nod, int st, int dr){
    if(st == dr){
        a[nod] = v[st];
        return;
    }
    int mij = (st + dr) >> 1;
    build(2*nod,st,mij);
    build(2*nod+1,mij+1,dr);
    a[nod] = max(a[2*nod],a[2*nod+1]);
}

void update(int nod, int st, int dr, int val, int pos){
    int mij = (st + dr) / 2;
    if(st == dr){
        a[nod] = val;
        return;
    }
    else{
        if(pos <= mij)
            update(2*nod,st,mij,val,pos);
        else
            update(2*nod+1,mij+1,dr,val,pos);
        a[nod] = max(a[2*nod],a[2*nod+1]);
    }
}

int querry(int nod, int st, int dr, int int1, int int2){
    if(int1 <= st && dr <= int2)
        return a[nod];
    else{
        int mij = (st + dr) / 2;
        int maxstanga = 0, maxdreapta = 0;
        if(int1 <= mij)
            maxstanga = querry(2*nod,st,mij,int1,int2);
        if(int2 > mij)
            maxdreapta = querry(2*nod+1,mij+1,dr,int1,int2);
        return max(maxstanga,maxdreapta);
    }
}

int main()
{
fin>>n>>m;
for(i=1;i<=n;i++)
    fin>>v[i];

build(1,1,n);

for(i=1;i<=m;i++){
    fin>>p>>b>>c;
    if(p == 1)
        update(1,1,n,c,b);
    else
        fout << querry(1,1,n,b,c) << '\n';
}
    return 0;
}