結果
| 問題 |
No.460 裏表ちわーわ
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2019-11-27 22:00:09 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 44 ms / 2,000 ms |
| コード長 | 1,983 bytes |
| コンパイル時間 | 729 ms |
| コンパイル使用メモリ | 74,428 KB |
| 実行使用メモリ | 6,820 KB |
| 最終ジャッジ日時 | 2024-11-15 17:00:23 |
| 合計ジャッジ時間 | 2,550 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 28 |
ソースコード
#include<iostream>
#include<vector>
using namespace std;
#define inRange(x,a,b) (a <= x && x < b)
int main(){
int h, w;
cin >> h >> w;
vector<vector<int>> v(h, vector<int>(w, 0));
for(int i = 0; i < h*w; i++) cin >> v[i/w][i%w];
int ans = 1<<30;
for(int s = 0; s < 1<<(h+w-1); s++){
int tmp = 0;
vector<vector<int>> t = v;
for(int j = 0; j < w; j++){
if((s>>j)&1){
tmp++;
for(int k = -1; k <= 1; k++){
for(int l = -1; l <= 1; l++){
if(inRange(0+k, 0, h)&&inRange(j+l, 0, w)){
t[0+k][j+l] = 1-t[0+k][j+l];
}
}
}
}
}
for(int i = 1; i < h; i++){
if((s>>(w+i-1))&1){
tmp++;
for(int k = -1; k <= 1; k++){
for(int l = -1; l <= 1; l++){
if(inRange(i+k, 0, h)&&inRange(0+l, 0, w)){
t[i+k][0+l] = 1-t[i+k][0+l];
}
}
}
}
}
for(int i = 1; i < h; i++){
for(int j = 1; j < w; j++){
if(t[i-1][j-1]){
tmp++;
for(int k = -1; k <= 1; k++){
for(int l = -1; l <= 1; l++){
if(inRange(i+k, 0, h)&&inRange(j+l, 0, w)){
t[i+k][j+l] = 1-t[i+k][j+l];
}
}
}
}
}
}
bool valid = true;
for(int i = 0; i < h; i++){
for(int j = 0; j < w; j++){
valid &= t[i][j]==0;
}
}
if(valid) ans = min(ans, tmp);
}
if(ans == 1<<30) cout << "Impossible" << endl;
else cout << ans << endl;
return 0;
}