結果

問題 No.179 塗り分け
ユーザー nenuon
提出日時 2017-03-02 23:37:53
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 2,237 bytes
コンパイル時間 821 ms
コンパイル使用メモリ 83,448 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-03 03:32:33
合計ジャッジ時間 2,175 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 6
other AC * 38 WA * 2
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <algorithm>
#include <cstdio>
#include <iostream>
#include <map>
#include <cmath>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <string>
#include <vector>
#include <stdlib.h>
#include <stdio.h>
#include <bitset>
using namespace std;

#define ll         long long
#define PI         acos(-1.0)
#define FOR(I,A,B) for(int I = (A); I < (B); ++I)

//方針
//ヒント見ましたTT
//ある#に対して移動量を(di, dj)として移動先が#ならok
//移動前と後の#を調査済みとする
//次に調査していない#に対して同じ作業をしていき
//全て調査済みになったらYESそうでないならNO
//-100<=di,dj<=100,

int main(){
    int H, W;
    cin >> H >> W;
    //getlineの前にcinがある場合はcin.ignore()しないとだめ
    cin.ignore();

    //長方形board
    vector<string> board;
    FOR(i, 0, H){
        string s;
        getline(cin, s);
        board.push_back(s);
    }

    bool YES = false;
    FOR(di, -H, H+1){
        FOR(dj, -W, W+1){
            //移動しないパターンはcontinue
            if(di == 0 && dj == 0) continue;

            //(di, dj)移動する時
            //調査したかどうか1ならした0ならしてない
            int isok[H][W];
            FOR(i, 0, H) FOR(j, 0, W) isok[i][j] = 0;

            //#を見ていく
            int check = 1;
            FOR(i, 0, H){
                FOR(j, 0, W){
                    //塗ってない#があったら移動先も塗る
                    if(isok[i][j]==0 && board[i][j]=='#'){
                        //移動先が範囲外ならbreak
                        if(i+di>=H || i+di<0 || j+dj>=W || j+dj<0){
                            check = 0;
                            break;
                          }
                        if(board[i+di][j+dj]=='.'){
                            check = 0;
                            break;
                        }
                        isok[i+di][j+dj] = 1;
                    }
                }
                if(!check) break;
            }
            if(check){
                cout << "YES" << endl;
                return 0;
            }
        }
    }
    cout << "NO" << endl;
}
0