1 条题解
-
-1yry123qazws LV 6 @ 2021-01-21 17:41:14
import java.math.BigInteger; import java.util.ArrayList; import java.util.List; import java.util.Scanner; public class Main { public int[] matrix = null; public int color = 0; public int n = 0; public int total = 0; public List<List<Integer>> list = new ArrayList<List<Integer>>(); /** * 分出隔离的区域 */ public void split() { int a = 0; while (a < matrix.length) { if (matrix[a] == 0) { List<Integer> set = new ArrayList<>(); list.add(set); matrix[a] = -1; set.add(a); search(a, set); } a++; } } private void search(int a, List<Integer> set) { if (a >= n) { if (matrix[a-n] == 0) { matrix[a-n] = -1; set.add(a-n); search(a-n, set); } if (a+1<2*n && matrix[a+1] == 0) { matrix[a+1] = -1; set.add(a+1); search(a+1, set); } if (a-1>n-1 && matrix[a-1] == 0) { matrix[a-1] = -1; set.add(a-1); search(a-1, set); } } else { if (matrix[a+n] == 0) { matrix[a+n] = -1; set.add(a+n); search(a+n, set); } if (a+1<n && matrix[a+1] == 0) { matrix[a+1] = -1; set.add(a+1); search(a+1, set); } if (a-1>-1 && matrix[a-1] == 0) { matrix[a-1] = -1; set.add(a-1); search(a-1, set); } } } /** * 搜索 */ public BigInteger print(List<Integer> set, BigInteger count) { BigInteger total = BigInteger.ZERO; List<Integer> recycle = new ArrayList<Integer>(); recycle.addAll(set); int o = set.remove(0); for (int c=1;c<=color;c++) { if (o < n) { if ((o+1<n && c == matrix[o+1]) || (o > 0 && c == matrix[o-1]) || (c == matrix[o+n])) { continue; } else { matrix[o] = c; } } else { if ((o+1<2*n && c == matrix[o+1]) || (o > n && c == matrix[o-1]) || c == matrix[o-n]) { continue; } else { matrix[o] = c; } } if (set.size() == 0) { total = total.add(BigInteger.ONE); } else { total = print(set, total); } // 还原 matrix[o] = -1; } // 还原 set.add(0, o); return count.add(total); } public static void main(String[] args) { Main print = new Main(); Scanner scanner = new Scanner(System.in); print.n = scanner.nextInt(); print.color = scanner.nextInt(); print.matrix = new int[2*print.n]; for (int i=0;i<2*print.n;i++) { print.matrix[i] = scanner.nextInt(); } scanner.close(); print.split(); BigInteger b = BigInteger.ONE; // 总方案数=各子区域方案数的积(高精度乘) for (int i=0;i<print.list.size();i++) { BigInteger count = print.print(print.list.get(i), BigInteger.ZERO); b = b.multiply(new BigInteger(String.valueOf(count))); b = b.mod(new BigInteger("1000000009")); } System.out.println(b.intValue()); } }
- 1
信息
- ID
- 2052
- 难度
- 8
- 分类
- (无)
- 标签
- (无)
- 递交数
- 70
- 已通过
- 7
- 通过率
- 10%
- 被复制
- 5
- 上传者