結果
問題 | No.460 裏表ちわーわ |
ユーザー | 37zigen |
提出日時 | 2016-12-12 09:45:55 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 215 ms / 2,000 ms |
コード長 | 3,206 bytes |
コンパイル時間 | 3,796 ms |
コンパイル使用メモリ | 84,432 KB |
実行使用メモリ | 58,260 KB |
最終ジャッジ日時 | 2024-11-29 15:30:52 |
合計ジャッジ時間 | 9,071 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 107 ms
53,012 KB |
testcase_01 | AC | 108 ms
52,876 KB |
testcase_02 | AC | 165 ms
57,100 KB |
testcase_03 | AC | 107 ms
53,084 KB |
testcase_04 | AC | 105 ms
53,088 KB |
testcase_05 | AC | 125 ms
54,120 KB |
testcase_06 | AC | 126 ms
53,896 KB |
testcase_07 | AC | 126 ms
54,156 KB |
testcase_08 | AC | 204 ms
57,740 KB |
testcase_09 | AC | 130 ms
54,012 KB |
testcase_10 | AC | 215 ms
57,988 KB |
testcase_11 | AC | 116 ms
53,376 KB |
testcase_12 | AC | 129 ms
54,124 KB |
testcase_13 | AC | 200 ms
57,952 KB |
testcase_14 | AC | 202 ms
57,280 KB |
testcase_15 | AC | 208 ms
57,964 KB |
testcase_16 | AC | 124 ms
53,832 KB |
testcase_17 | AC | 181 ms
57,656 KB |
testcase_18 | AC | 186 ms
58,200 KB |
testcase_19 | AC | 199 ms
58,220 KB |
testcase_20 | AC | 128 ms
53,836 KB |
testcase_21 | AC | 189 ms
57,488 KB |
testcase_22 | AC | 208 ms
57,984 KB |
testcase_23 | AC | 199 ms
58,260 KB |
testcase_24 | AC | 212 ms
58,112 KB |
testcase_25 | AC | 125 ms
54,000 KB |
testcase_26 | AC | 121 ms
53,856 KB |
testcase_27 | AC | 120 ms
54,060 KB |
ソースコード
package yukicoder; import java.util.*; public class Q460 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int M = sc.nextInt(); int N = sc.nextInt(); int[][] a = new int[M][N]; for (int i = 0; i < M; ++i) { for (int j = 0; j < N; ++j) { a[i][j] = sc.nextInt(); } } int[][] mx = new int[M * N][M * N]; int[] v = new int[M * N]; for (int i = 0; i < M; ++i) { for (int j = 0; j < N; ++j) { v[i * N + j] = a[i][j]; } } for (int i = 0; i < M; ++i) { for (int j = 0; j < N; ++j) { for (int dx = -1; dx <= 1; ++dx) { for (int dy = -1; dy <= 1; ++dy) { int nx = j + dx; int ny = i + dy; if (nx < 0 || ny < 0 || nx >= N || ny >= M) continue; mx[i * N + j][ny * N + nx] = 1; } } } } for (int i = 0; i < M * N; ++i) { int j = i; while (j < M * N && mx[j][i] == 0) { ++j; } if (j == M * N) continue; if (i != j) { int[] dRow=mx[i]; mx[i]=mx[j]; mx[j]=dRow; int d = v[i]; v[i] = v[j]; v[j] = d; } for (int k = 0; k < M * N; ++k) { if (k == i) continue; if (mx[k][i] == 1) { for (int l = 0; l < M * N; ++l) { mx[k][l] = (mx[k][l] + mx[i][l]) % 2; } v[k] = (v[k] + v[i]) % 2; } } } ArrayList<Integer>[] to = new ArrayList[N * M]; for (int i = 0; i < N * M; ++i) { to[i] = new ArrayList<>(); } int c = 0; ArrayList<Integer> pending = new ArrayList<>(); for (int i = N * M - 1; i >= 0; --i) { for (int k = 0; k < N * M; ++k) { if (mx[i][k] == 1) { to[k].add(i); } } ArrayDeque<Integer> tmp = new ArrayDeque<>(); for (int k = i + 1; k < N * M; ++k) { if (mx[i][k] == 1) { tmp.add(k); } } if (tmp.size() > 0) { pending.addAll(tmp); continue; } if (tmp.size() == 0 && mx[i][i] == 1 && v[i] == 1) { ++c; for (int k = 0; k <= i; ++k) { if (mx[k][i] == 1) { v[k] = v[k] ^ 1; } } } else if (v[i] == 1 && mx[i][i] == 0 && tmp.size() == 0) { if (mx[i][i] != 1) { System.out.println("Impossible"); return; } } } int ans = Integer.MAX_VALUE; Collections.sort(pending); for (int i = 0; i < pending.size(); ++i) { while (i + 1 < pending.size() && pending.get(i) == pending.get(i + 1)) { pending.remove(i + 1); } } out: for (int i = 0; i < (1 << pending.size()); ++i) { int[] nv = Arrays.copyOf(v, v.length); int used = 0; for (int k = 0; k < pending.size(); ++k) { if ((i & (1 << k)) > 0) { ++used; for (int t : to[pending.get(k)]) { nv[t] ^= 1; } } } for (int j = 0; j < N * M; ++j) { if (nv[j] == 1) { if (mx[j][j] == 0) continue out; else { ++used; nv[j] ^= 1; } } } ans = Math.min(ans, c + used); } System.out.println(ans); } static void show(int[][] mx, int[] v, int M, int N) { for (int i = 0; i < M * N; ++i) { for (int j = 0; j < M * N; ++j) { System.out.print(mx[i][j] + " "); } System.out.print(v[i]); System.out.println(); } } static void tr(Object... objects) { System.out.println(Arrays.deepToString(objects)); } }