This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#pragma GCC optimize("O3")
#define int long long
using namespace std;
typedef long long ll;
typedef long double ld;
vector<vector<ll>> v,S1,S2,toadd;
int n,m,k,q;
int nradds=0;
void add(int x1,int y1,int x2,int y2,ll val)
{
x1=max(x1,1LL);
y1=max(y1,1LL);
x2=min(x2,n);
y2=min(y2,m);
v[x1][y1]+=val;
v[x2+1][y1]-=val;
v[x1][y2+1]-=val;
v[x2+1][y2+1]+=val;
}
void putadd(int x1,int y1,int x2,int y2,ll val)
{
toadd[x1][y1]+=val;
toadd[x2+1][y1]-=val;
toadd[x1][y2+1]-=val;
toadd[x2+1][y2+1]+=val;
}
ll getsum(int x1,int y1,int x2,int y2)
{
return v[x2][y2]-v[x1-1][y2]-v[x2][y1-1]+v[x1-1][y1-1];
}
ll put[2][2500005];
ll s[2500005];
signed main()
{
ios_base::sync_with_stdio(false);
cin.tie(0);
cin>>n>>m>>k;
if(m==1)
{
for(int z=1;z<=k;z++)
{
ll x,y,a,b;
cin>>x>>y>>a>>b;
//assert(y==1);
ll nr=a/b;
put[0][x]+=a;
put[0][x+1]-=a;
ll st=x-nr;
ll dr=x-1;
if(dr>0)
{
st=max(st,1LL);
ll lg=dr-st+2;
put[0][st]+=a-lg*b;
put[0][dr+1]-=a-lg*b;
put[0][dr+1]-=(lg-1)*b;
put[1][st]+=b;
put[1][dr+1]-=b;
}
st=x+1;
dr=x+nr;
if(st<=n)
{
dr=min(dr,n*1LL);
ll lg=dr-st+2;
put[0][st]+=a;
put[0][dr+1]-=a;
put[0][dr+1]-=(lg-1)*(-b);
put[1][st]-=b;
put[1][dr+1]+=b;
}
}
ll suma=0;
for(int i=1;i<=n;i++)
{
suma+=put[0][i];
s[i]=suma;
}
ll si=0;
suma=0;
for(int i=1;i<=n;i++)
{
si+=put[1][i];
suma+=si;
s[i]+=suma;
}
for(int i=1;i<=n;i++)
s[i]+=s[i-1];
cin>>q;
while(q--)
{
int x1,y1,x2,y2;
cin>>x1>>y1>>x2>>y2;
//assert(y1==1&&y2==1);
ll val=s[x2]-s[x1-1];
ll rez=round(ld(val)/ld(x2-x1+1));
cout<<rez<<'\n';
}
return 0;
}
v.resize(n+5);
S1.resize(n+5);
S2.resize(n+5);
toadd.resize(n+5);
for(int i=0;i<=n+4;i++)
{
v[i].resize(m+5);
S1[i].resize(m+5);
S2[i].resize(m+5);
toadd[i].resize(m+5);
}
for(int z=1;z<=k;z++)
{
int x,y,a,b;
cin>>x>>y>>a>>b;
int nr=a;
int x1=x,y1=y,x2=x,y2=y;
int cnt=a/b;
if(a%b==0)
cnt--;
if(cnt==0)
{
add(x,y,x,y,a);
continue;
}
x1=x-cnt;
x2=x+cnt;
y1=y-cnt;
y2=y+cnt;
add(x1,y1,x2,y2,a);
add(x1,y1,x2,y2,-(cnt+1)*b);
/*while(x1<=x)
{
add(x1,y1,x2,y2,b);
x1++;
y1++;
x2--;
y2--;
}*/
int i=x1,j=y1;
/*while(i<=x)
{
int p=max(i,1LL);
int q=max(j,1LL);
v[p][q]+=b;
i++;
j++;
}*/
ll nr11=max(0LL,min(1-x1,1-y1));
v[1][1]+=nr11*b;
i+=nr11;
j+=nr11;
if(i<1)
{
ll cnt=1-i;
ll st=j;
ll dr=j+cnt-1;
putadd(1,st,1,dr,b);
i+=cnt;
j+=cnt;
}
if(j<1)
{
ll cnt=1-j;
ll st=i;
ll dr=i+cnt-1;
putadd(st,1,dr,1,b);
i+=cnt;
j+=cnt;
}
S1[i][j]+=b;
S1[x+1][y+1]-=b;
i=x+1;
j=y+1;
/*while(i<=x2+1&&i<=n&&j<=m&&j<=y2+1)
{
v[i][j]+=b;
i++;
j++;
}*/
S1[i][j]+=b;
if(!(x2+2>n||y2+2>m))
S1[x2+2][y2+2]-=b;
i=x1;
j=y2+1;
ll num=max(0LL,j-m);
i+=num;
j-=num;
if(i<1)
{
ll cnt=1-i;
ll st=j-cnt+1;
ll dr=j;
putadd(1,st,1,dr,-b);
i+=cnt;
j-=cnt;
}
num=x-i;
S2[i][j]-=b;
S2[i+num+1][j-(num+1)]+=b;
/*while(i<=x)
{
int p=max(i,1LL);
int q=j;
if(q<=m)
v[p][q]-=b;
i++;
j--;
}*/
i=i+num+1;
j=j-(num+1);
ll limit=min(x2+1,n);
if(i>limit)
continue;
ll to1=max(0LL,j);
num=limit-i+1;
ll ij=i+min(num-1,to1-1);
ll jj=j-min(num-1,to1-1);
S2[i][j]-=b;
S2[ij+1][jj-1]+=b;
i=ij+1;
j=jj-1;
if(i<=limit)
{
ll st=i;
ll dr=limit;
putadd(st,1,dr,1,-b);
}
/*while(i<=x2+1&&i<=n)
{
int p=i;
int q=max(j,1LL);
v[p][q]-=b;
i++;
j--;
}*/
//S2[i][j]-=b;
/*if(x2+2>n||y1-1<1)
continue;
S2[x2+2][y1-1]+=b;*/
}
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
toadd[i][j]+=toadd[i-1][j]+toadd[i][j-1]-toadd[i-1][j-1];
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
v[i][j]+=toadd[i][j];
for(int i=1;i<=n;i++)
{
ll x=i,y=1;
ll suma=0;
while(x<=n&&y<=m)
{
suma+=S1[x][y];
v[x][y]+=suma;
x++;
y++;
}
}
for(int j=2;j<=m;j++)
{
ll x=1,y=j;
ll suma=0;
while(x<=n&&y<=m)
{
suma+=S1[x][y];
v[x][y]+=suma;
x++;
y++;
}
}
for(int i=1;i<=n;i++)
{
ll x=i,y=m;
ll suma=0;
while(x<=n&&y>0)
{
suma+=S2[x][y];
v[x][y]+=suma;
x++;
y--;
}
}
for(int j=1;j<m;j++)
{
ll x=1,y=j;
ll suma=0;
while(x<=n&&y>0)
{
suma+=S2[x][y];
v[x][y]+=suma;
x++;
y--;
}
}
/*for(int i=1;i<=n;i++,cout<<'\n')
for(int j=1;j<=m;j++)
cout<<v[i][j]<<' ';*/
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
v[i][j]+=v[i-1][j]+v[i][j-1]-v[i-1][j-1];
/*for(int i=1;i<=n;i++,cout<<'\n')
for(int j=1;j<=m;j++)
cout<<v[i][j]<<' ';*/
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
v[i][j]=v[i][j]+v[i-1][j]+v[i][j-1]-v[i-1][j-1];
//cout<<s[i][j]<<' ';
}
//assert(nradds<=k*max(n,m));
cin>>q;
while(q--)
{
int x1,y1,x2,y2;
cin>>x1>>y1>>x2>>y2;
ll suma=getsum(x1,y1,x2,y2);
ll cells=(y2-y1+1)*(x2-x1+1);
ll rez=round(ld(suma)/ld(cells));
cout<<rez<<'\n';
}
return 0;
}
Compilation message (stderr)
nuclearia.cpp: In function 'int main()':
nuclearia.cpp:117:13: warning: unused variable 'nr' [-Wunused-variable]
117 | int nr=a;
| ^~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |