Submission #996955

#TimeUsernameProblemLanguageResultExecution timeMemory
996955coolboy19521Bitaro the Brave (JOI19_ho_t1)C++17
50 / 100
1027 ms69448 KiB
#pragma GCC optimize("Ofast") #include<bits/stdc++.h> #define int long long using namespace std; const int sz = 3e3 + 9; char a[sz][sz]; signed main() { cin.tie(nullptr)->sync_with_stdio(false); int h, w; cin >> h >> w; map <int, vector <int>> os, is; int r = 0; for (int i = 1; i <= h; i ++) { for (int j = 1; j <= w; j ++) { cin >> a[i][j]; if ('O' == a[i][j]) { os[i].push_back(j); } else if ('I' == a[i][j]) { is[j].push_back(i); } } } for (int i = 1; i <= h; i ++) { for (int j = 1; j <= w; j ++) { if ('J' == a[i][j]) { if (!os.count(i) || !is.count(j)) continue; int oc = os[i].end() - upper_bound(begin(os[i]), end(os[i]), j); int ic = is[j].end() - upper_bound(begin(is[j]), end(is[j]), i); r += oc * ic; } } } cout << r << '\n'; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...