社区讨论
很简单的一道题求助
题目总版参与者 6已保存回复 9
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 9 条
- 当前快照
- 1 份
- 快照标识符
- @locllkzq
- 此快照首次捕获于
- 2023/10/30 15:48 2 年前
- 此快照最后确认于
- 2023/11/05 02:57 2 年前
https://loj.ac/p/6282
分块哪错了
CPP#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N=1e5+5;
typedef long long ll;
ll a[N],sum[N],add[N];
int n,m,B;
int get(int x)
{
return (x+B-1)/B;
}
signed main()
{
cin>>n>>m;
B=sqrt(n);
for(int i=1;i<=n;i++)
{
cin>>a[i];
sum[get(i)]+=a[i];
}
while(m--)
{
int op,l,r,x;
cin>>op>>l>>r;
int idl=get(l),idr=get(r);
if(op==1)
{
cin>>x;
if(idl==idr)
{
for(int i=l;i<=r;i++)
{
a[i]*=x;
a[i]%=10007;
}
sum[idl]*=(r-l+1)*x;
sum[idl]%=10007;
}
else
{
for(int i=idl+1;i<=idr-1;i++)
{
add[i]*=x;
add[i]%=10007;
}
for(int i=l;i<=idl*B;i++)
{
a[i]*=x;
a[i]%=10007;
}
sum[idl]*=(idl*B-l+1)*x;
for(int i=(idr-1)*B+1;i<=r;i++)
{
a[i]*=x;
a[i]%=10007;
}
sum[idr]*=(r-(idr-1)*B)*x;
sum[idr]%=10007;
}
}
else if(op==0)
{
cin>>x;
if(idl==idr)
{
for(int i=l;i<=r;i++)
{
a[i]+=x;
a[i]%=10007;
}
sum[idl]+=(r-l+1)*x;
sum[idl]%=10007;
}
else
{
for(int i=idl+1;i<=idr-1;i++)
{
add[i]+=x;
add[i]%=10007;
}
for(int i=l;i<=idl*B;i++)
{
a[i]+=x;
a[i]%=10007;
}
sum[idl]+=(idl*B-l+1)*x;
sum[idl]%=10007;
for(int i=(idr-1)*B+1;i<=r;i++)
{
a[i]+=x;
a[i]%=10007;
}
sum[idr]+=(r-(idr-1)*B)*x;
}
}
else if(op==2)
{
ll ans=0;
if(idl==idr)
{
for(int i=l;i<=r;i++)
{
ans+=a[i]+add[idl];
}
}
else
{
for(int i=idl+1;i<=idr-1;i++)
{
ans+=sum[i]+add[i]*B;
ans%=10007;
}
for(int i=l;i<=idl*B;i++)
{
ans+=a[i]+add[idl];
ans%=10007;
}
for(int i=(idr-1)*B+1;i<=r;i++)
{
ans+=a[i]+add[idr];
ans%=10007;
}
}
cout<<ans%10007<<endl;
}
}
}
回复
共 9 条回复,欢迎继续交流。
正在加载回复...