社区讨论
树状数组写炸求条
P1438无聊的数列参与者 2已保存回复 4
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 4 条
- 当前快照
- 1 份
- 快照标识符
- @m00qz1yj
- 此快照首次捕获于
- 2024/08/19 16:41 2 年前
- 此快照最后确认于
- 2025/11/04 23:03 4 个月前
CPP
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N=1e5+5;
int lowbit(int x)
{
return x&-x;
}
int n,m;
int tree1[N],tree2[N];
int id,l,r,k,d,a;
void update(int x,int k)
{
for(int i=x;i<=n;i+=lowbit(i))
{
tree1[i]+=k;
tree2[i]+=k*i;
}
}
int sum(int x)
{
int ans=0;
for(int i=x;i;i-=lowbit(i))
{
ans+=tree1[i]*(x+1)-tree2[i];
}
return ans;
}
signed main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>a;
update(i,a);
update(i+1,-2*a);
update(i+2,a);
for(int i=1;i<=n;i++)
cout<<sum(i)<<' ';
cout<<'\n';
}
while(m--)
{
cin>>id;
if(id==1)
{
cin>>l>>r>>k>>d;
update(l,k);
update(l+1,d-k);
update(r+1,-(k+(r-l+1)*d));
update(r+2,(r-l)*d+k);
for(int i=1;i<=n;i++)
cout<<sum(i)<<' ';
cout<<'\n';
}
else
{
cin>>l;
cout<<sum(l)<<'\n';
for(int i=1;i<=n;i++)
cout<<sum(i)<<' ';
cout<<'\n';
}
}
return 0;
}
输出5
回复
共 4 条回复,欢迎继续交流。
正在加载回复...