結果
問題 | No.179 塗り分け |
ユーザー |
|
提出日時 | 2015-04-06 00:00:51 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 8 ms / 3,000 ms |
コード長 | 1,484 bytes |
コンパイル時間 | 774 ms |
コンパイル使用メモリ | 57,620 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-07-23 14:25:15 |
合計ジャッジ時間 | 1,668 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 6 |
other | AC * 40 |
ソースコード
#include<iostream> using namespace std; const int BUF = 55; int row, col; char b[BUF][BUF]; void read() { cin >> row >> col; for (int i = 0; i < row; ++i) for (int j = 0; j < col; ++j) cin >> b[i][j]; } void work() { bool exist = false; for (int i = 0; i < row; ++i) for (int j = 0; j < col; ++j) if (b[i][j] == '#') exist = true; if (!exist) { cout << "NO" << endl; return; } for (int dr = 0; dr < row; ++dr) for (int dc = -col + 1; dc < col; ++dc) { if (dr == 0 && dc == 0) continue; bool used[BUF][BUF] = {}; for (int r = 0; r < row; ++r) { for (int c = (dc < 0 ? col - 1 : 0); (dc < 0 ? c >= 0 : c < col); (dc < 0 ? --c : ++c)) { if (b[r][c] == '#' && !used[r][c]) { if (0 <= r + dr && r + dr < row && 0 <= c + dc && c + dc < col && b[r + dr][c + dc] == '#') { used[r][c] = used[r + dr][c + dc] = true; } else { goto _fail; } } } } cout << "YES" << endl; return; _fail:; } cout << "NO" << endl; } int main() { read(); work(); return 0; }