Submission #1151492

#TimeUsernameProblemLanguageResultExecution timeMemory
1151492thecrazycandyCollecting Mushrooms (NOI18_collectmushrooms)C++20
100 / 100
17 ms13640 KiB
#include <bits/stdc++.h>
//#pragma GCC optimize("Ofast")
//#pragma GCC target("avx,avx2,fma")
using namespace std;
#define sped_up ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
#define ll long long
const ll INF = (ll)1e9 + 1, INFL = (ll)1e18 + 1;
const ll mod = (ll)1e9 + 7, MAXN = (ll)2e5 + 1;
int main () {
    sped_up;
    ll n, m, d, x;
    cin >> n >> m >> d >> x;
    ll cnt = 0;
    ll t[n + 2][m + 2];
    char a[n + 2][m + 2];
    for (int i = 0; i <= n + 1; i++) {
        for (int j = 0; j <= m + 1; j++) {
            t[i][j] = 0;
        }
    }
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> a[i][j];
            if (a[i][j] == 'S') {
                t[max(1ll, i - d)][max(1ll, j - d)]++;
                t[max(1ll, i - d)][min(m + 1, j + d + 1)]--;
                t[min(n + 1, i + d + 1)][max(1ll, j - d)]--;
                t[min(n + 1, i + d + 1)][min(m + 1, j + d + 1)]++;
            }
        }
    }
    for (int i = 1; i <= n + 1; i++) {
        for (int j = 1; j <= m + 1; j++) {
            t[i][j] += t[i][j - 1];
        }
    }
    for (int i = 1; i <= n + 1; i++) {
        for (int j = 1; j <= m + 1; j++) {
            t[i][j] += t[i - 1][j];
        }
    }
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            if (a[i][j] == 'M' && t[i][j] >= x) cnt++;
        }
    }
    cout << cnt;
}
#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...