結果
| 問題 |
No.179 塗り分け
|
| コンテスト | |
| ユーザー |
spacia
|
| 提出日時 | 2016-01-23 14:47:14 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 560 ms / 3,000 ms |
| コード長 | 1,416 bytes |
| コンパイル時間 | 622 ms |
| コンパイル使用メモリ | 67,508 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-23 14:33:42 |
| 合計ジャッジ時間 | 2,496 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 6 |
| other | AC * 40 |
コンパイルメッセージ
main.cpp: In function ‘bool search(int, int)’:
main.cpp:32:1: warning: control reaches end of non-void function [-Wreturn-type]
32 | }
| ^
ソースコード
#include <stdio.h>
#include <stdlib.h>
#include <string>
#include <utility>
#include <vector>
#include <algorithm>
#include <functional>
#include <iostream>
using namespace std;
int size;
vector<int> v;
bool *check;
bool search (int cnt , int sub) {
if (cnt == size / 2) return true;
for (int i = 0; i < size; i++) {
if (check[i]) continue;
check[i] = true;
for (int j = 0; j < size; j++) {
if (check[j]) continue;
if (abs(v[i] - v[j]) == sub) {
check[j] = true;
if (search(cnt + 1 , sub)) return true;
check[j] = false;
}
}
check[i] = false;
return false;
}
}
bool solve () {
size = v.size();
if (size % 2 == 1) return false;
check = new bool[size];
for (int i = 1; i < size; i++) check[i] = false;
check[0] = true;
for (int i = 1; i < size; i++) {
check[i] = true;
if (search(1,v[i] - v[0])) return true;
check[i] = false;
}
return false;
}
int main () {
cin.tie(0);
ios::sync_with_stdio(false);
int h , w;
cin >> h >> w;
string s;
for (int i = 0; i < h; i++) {
cin >> s;
for (int j = 0; j < w; j++) {
if (s.at(j) == '#') {
v.push_back(i << 8 | j);
}
}
}
cout << (solve() ? "YES" : "NO") << "\n";
}
spacia