为什么60tps

P2367 语文成绩

tangml @ 2024-07-01 20:07:37

初学OI,不知道哪里错了

#include<bits/stdc++.h>

using namespace std;

const int N=5e6+100;

int a[N+1];

struct NODE{
    int l,r;
    long long data,add;
}t[4*N+1];

void bulid(int p,int l,int r);
void spread(int p);
void change(int p,int x,int y,int z);
long long ask(int p,int x,int y);

int main(){
    int n,m;
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
    scanf("%d",&a[i]);
    bulid(1,1,n);
    int x,y,z;
    for(int i=1;i<=m;i++)
    {
        scanf("%d%d%d",&x,&y,&z);
        change(1,x,y,z);
    } 
    cout<<t[1].dat<<endl;
    return 0;
}
void bulid(int p,int l,int r)
{
    t[p].l=l;t[p].r=r;
    if(l==r)
    {
        t[p].data=a[l];
        return;
    }
    int mid=l+r>>1;
    bulid(p*2,l,mid);
    bulid(p*2+1,mid+1,r);
    t[p].data=min(t[p*2].data,t[p*2+1].data);
} 

void spread(int p)
{
    if(t[p].add)
    {
        t[p*2].data+=t[p].add*(t[p*2].r-t[p*2].l+1);
        t[p*2+1].data+=t[p].add*(t[p*2+1].r-t[p*2+1].l+1);
        t[p*2].add+=t[p].add;
        t[p*2+1].add+=t[p].add;
        t[p].add=0;
    }
}

void change(int p,int x,int y,int z)
{
    if(x<=t[p].l && y>=t[p].r)
    {
        t[p].data+=(int)z*(t[p].r-t[p].l+1);
        t[p].add+=z;
        return;
    }
    spread(p);
    int mid=t[p].l+t[p].r>>1;
    if(x<=mid) change(p*2,x,y,z);
    if(y>mid) change(p*2+1,x,y,z);
     t[p].data=min(t[p*2].data,t[p*2+1].data);
}

long long ask(int p,int x,int y)
{
    if(x<=t[p].l && y>=t[p].r) return t[p].data;
    spread(p);
    int mid=t[p].l+t[p].r>>1;
    long long ans=0x3f3f3f3f;
    if(x<=mid) ans=min(ans,ask(p*2,x,y));
    if(y>mid) ans=min(ans,ask(p*2+1,x,y));
    return ans;
}

by tangml @ 2024-07-01 20:17:34

看上去就是一个板子题啊


by jcf666 @ 2024-07-06 22:32:35

《用线段树》《初学OI》这我真改不了一点


by abc20131113 @ 2024-07-15 20:48:48

这个......可不可一些短一点


|