제출 #867289

#제출 시각아이디문제언어결과실행 시간메모리
867289Muhammad_AneeqNuclearia (CEOI15_nuclearia)C++17
0 / 100
1058 ms61360 KiB
/* بسم الله الرحمن الرحيم Author: (:Muhammad Aneeq:) */ #pragma GCC optimize("O2") #pragma GCC optimize("Ofast") #pragma GCC target("avx,avx2,fma") #include <iostream> #include <cmath> using namespace std; #define int long long inline void solve() { int h,w; cin>>h>>w; int a[h][w]={}; int x; cin>>x; while (x--) { int i,j,y,z; cin>>i>>j>>y>>z; i--;j--; for (int k=max(0LL,i-((y+z-1)/z)+1);k<min(h,i+((y+z-1)/z));k++) { for (int l=max(0LL,j-((y+z-1)/z)+1);l<min(w,j+((y+z-1)/z));l++) { a[k][l]+=y-z*max(abs(k-i),abs(l-j)); } } } int pre[h+1][w+1]={}; for (int i=0;i<h;i++) { for (int j=0;j<w;j++) { pre[i+1][j+1]=pre[i+1][j]+pre[i][j+1]-pre[i][j]+a[i][j]; } } int q; cin>>q; while (q--) { int a,b,c,d; cin>>a>>b>>c>>d; int f=pre[c][d]-pre[c][b-1]-pre[a-1][d]+pre[a-1][b-1]; long double g=(c-a+1)*(d-b+1); cout<<round(f/g)<<'\n'; } } signed main() { ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL); solve(); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...