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
这个......可不可一些短一点