結果
| 問題 | No.2692 How Many Times Reached? | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2024-03-22 21:49:52 | 
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 2 ms / 2,000 ms | 
| コード長 | 2,135 bytes | 
| コンパイル時間 | 866 ms | 
| コンパイル使用メモリ | 99,200 KB | 
| 実行使用メモリ | 6,820 KB | 
| 最終ジャッジ日時 | 2024-09-30 11:18:26 | 
| 合計ジャッジ時間 | 1,982 ms | 
| ジャッジサーバーID (参考情報) | judge1 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 4 | 
| other | AC * 43 | 
ソースコード
#define _USE_MATH_DEFINES
#include <iostream>		//cin, cout
#include <vector>		//vector
#include <algorithm>	//sort,min,max,count
#include <string>		//string,getline, to_string
#include <cstdlib>		//abs(int)
#include <utility>		//swap, pair
#include <deque>		//deque
#include <climits>		//INT_MAX
#include <bitset>		//bitset
#include <cmath>		//sqrt, ceil. M_PI, pow, sin
#include <ios>			//fixed
#include <iomanip>		//setprecision
#include <sstream>		//stringstream
#include <numeric>		//gcd, assumlate
#include <random>		//randam_device
#include <limits>		//numeric_limits
#include <time.h>       //tm
using namespace std;
constexpr int64_t D_MOD = 1000000007;
constexpr int64_t F_MOD = 998244353;
int main() {
    int N;
    cin >> N;
    vector<string> S(N);
    int ans = 0;
    int cntd = 0;
    int cntb = 0;
    for (int i = 0; i < N; i++) {
        cin >> S.at(i);
        cntd = 0;
        cntb = 0;
        for (int j = 0; j < N; j++) {
            if (S.at(i).at(j) == '.') {
                cntd++;
            }
            else if (S.at(i).at(j) == 'B') {
                cntb++;
            }
        }
        if (cntd == 1 && cntb == 0) {
            ans++;
        }
    }
    for (int i = 0; i < N; i++) {
        cntd = 0;
        cntb = 0;
        for (int j = 0; j < N; j++) {
            if (S.at(j).at(i) == '.') {
                cntd++;
            }
            else if (S.at(j).at(i) == 'B') {
                cntb++;
            }
        }
        if (cntd == 1 && cntb == 0) {
            ans++;
        }
    }
    cntd = 0;
    cntb = 0;
    for (int i = 0; i < N; i++) {
        if (S.at(i).at(i) == '.') {
            cntd++;
        }
        else if (S.at(i).at(i) == 'B') {
            cntb++;
        }
    }
    if (cntd == 1 && cntb == 0) {
        ans++;
    }
    cntd = 0;
    cntb = 0;
    for (int i = 0; i < N; i++) {
        if (S.at(i).at(N - i - 1) == '.') {
            cntd++;
        }
        else if (S.at(i).at(N - i - 1) == 'B') {
            cntb++;
        }
    }
    if (cntd == 1 && cntb == 0) {
        ans++;
    }
    cout << ans << endl;
    return 0;
}
            
            
            
        