Cod sursa(job #2547194)

Utilizator catalingudiu@yahoo.roGudiu Catalin [email protected] Data 15 februarie 2020 09:43:29
Problema Arbori de intervale Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.02 kb
#include <bits/stdc++.h>
using namespace std;
ifstream in("arbint.in");
ofstream out("arbint.out");
int ar[400010],n,m;
void up(int st,int dr,int poz,int poza,int val)
{
    if(st>poz||dr<poz)
        return;
    if(st==dr)
    {
        ar[poza]=val;
        return;
    }
    int mij=(dr+st)/2;
    up(st,mij,poz,poza*2,val);
    up(mij+1,dr,poz,poza*2+1,val);
    ar[poza]=max(ar[poza*2],ar[poza*2+1]);
}
int fnd(int st,int dr,int poza,int a,int b)
{
    if(st>b||dr<a)
        return 0;
    if(st>=a&&dr<=b)
        return ar[poza];
    int mij=(dr+st)/2;
    int fnd1,fnd2;
    fnd1=fnd(st,mij,poza*2,a,b);
    fnd2=fnd(mij+1,dr,poza*2+1,a,b);
    return max(fnd1,fnd2);
}
int main()
{
    in>>n>>m;
    for(int i=1;i<=n;i++)
    {
        int val;
        in>>val;
        up(1,n,i,1,val);
    }
    for(int i=1;i<=m;i++)
    {
        int v,a,b;
        in>>v>>a>>b;
        if(v==1)
            up(1,n,a,1,b);
        if(v==0)
            out<<fnd(1,n,1,a,b)<<'\n';
    }
    return 0;
}