TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Grid Repainting 2

問題

C – Grid Repainting 2
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

  1. すべてのマスを調べる。
  2. 今見ているマスが#のとき、上下左右のすべてのマスが.の場合は目標を達成することができない。

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<nt, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 60;
// const int INF = 1001001001;

// ABC096-C
// https://atcoder.jp/contests/abc096/tasks/abc096_c

int main() {
  int H, W;
  cin >> H >> W;

  vector<string> s(H);
  rep(i, H) { cin >> s[i]; }

  vector<int> dy = {-1, 0, 1, 0};
  vector<int> dx = {0, -1, 0, 1};

  rep(i, H) {
    rep(j, W) {
      if(s[i][j] == '#') {
        bool flg = false;
        for(int k = 0; k < 4; ++k) {
          int nh = i + dy[k];
          int nw = j + dx[k];
          if(nh < 0 || H <= nh || nw < 0 || W <= nw) {
            continue;
          }
          if(s[nh][nw] == '#') {
            flg = true;
            break;
          }
        }
        if(flg == false) {
          cout << "No" << endl;
          return 0;
        }
      }
    }
  }

  cout << "Yes" << endl;
  return 0;
}