제출 #898048

#제출 시각아이디문제언어결과실행 시간메모리
898048andrei_iorgulescuDango Maker (JOI18_dango_maker)C++14
13 / 100
1 ms2648 KiB
#include <bits/stdc++.h> using namespace std; int n,m; char a[3005][3005]; bool viz[3005][3005]; int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); cin >> n >> m; for (int i = 1; i <= n; i++) for (int j = 1; j <= m; j++) cin >> a[i][j]; int ans = 0; for (int i = 1; i <= n; i++) { for (int j = 1; j <= m - 2; j++) { if (a[i][j] == 'R' and a[i][j + 1] == 'G' and a[i][j + 2] == 'W' and !viz[i][j] and !viz[i][j + 1] and !viz[i][j + 2]) { ans++; viz[i][j] = true; viz[i][j + 1] = true; viz[i][j + 2] = true; } } } for (int j = 1; j <= m; j++) { for (int i = 1; i <= n - 2; i++) { if (a[i][j] == 'R' and a[i + 1][j] == 'G' and a[i + 2][j] == 'W' and !viz[i][j] and !viz[i + 1][j] and !viz[i + 2][j]) { ans++; viz[i][j] = true; viz[i + 1][j] = true; viz[i + 2][j] = true; } } } for (int i = 1; i <= n; i++) for (int j = 1; j <= m; j++) viz[i][j] = false; int ans2 = 0; for (int j = 1; j <= m; j++) { for (int i = 1; i <= n - 2; i++) { if (a[i][j] == 'R' and a[i + 1][j] == 'G' and a[i + 2][j] == 'W' and !viz[i][j] and !viz[i + 1][j] and !viz[i + 2][j]) { ans2++; viz[i][j] = true; viz[i + 1][j] = true; viz[i + 2][j] = true; } } } for (int i = 1; i <= n; i++) { for (int j = 1; j <= m - 2; j++) { if (a[i][j] == 'R' and a[i][j + 1] == 'G' and a[i][j + 2] == 'W' and !viz[i][j] and !viz[i][j + 1] and !viz[i][j + 2]) { ans2++; viz[i][j] = true; viz[i][j + 1] = true; viz[i][j + 2] = true; } } } cout << max(ans,ans2); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...