結果
| 問題 | 
                            No.179 塗り分け
                             | 
                    
| コンテスト | |
| ユーザー | 
                             nenuon
                         | 
                    
| 提出日時 | 2017-03-02 23:42:31 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 14 ms / 3,000 ms | 
| コード長 | 2,435 bytes | 
| コンパイル時間 | 919 ms | 
| コンパイル使用メモリ | 85,948 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-07-23 14:41:35 | 
| 合計ジャッジ時間 | 2,470 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge1 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 6 | 
| other | AC * 40 | 
ソースコード
#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
    int n_sharp = 0;
    vector<string> board;
    FOR(i, 0, H){
        string s;
        getline(cin, s);
        FOR(i, 0, s.length()) if(s[i]=='#') n_sharp++;
        board.push_back(s);
    }
    //#が0or奇数個ならNO
    if(n_sharp==0 || n_sharp%2==1){
        cout << "NO" << endl;
        return 0;
    }
    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;
}
            
            
            
        
            
nenuon