搭积木
小明最近喜欢搭数字积木,
一共有10块积木,每个积木上有一个数字,0~9。
搭积木规则:
每个积木放到其它两个积木的上面,并且一定比下面的两个积木数字小。
最后搭成4层的金字塔形,必须用完所有的积木。
下面是两种合格的搭法:
0
1 2
3 4 5
6 7 8 9
0
3 1
7 5 2
9 8 6 4
请你计算这样的搭法一共有多少种?
请填表示总数目的数字。
注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字。
答案 768
代码
public class Main {
static int[] mk = new int[10];
static int sum = 0;
public static void main(String[] args) {
int[][] arr = new int[4][4];
for (int i = 0; i < 10; i++) {
dfs(arr, 3, 0, i);
}
System.out.println(sum);
}
public static void dfs(int[][] arr, int stepx, int stepy, int a) {
if (mk[a] == 1 || stepx < 0 || stepy > stepx || stepy > 3) {
return;
}
arr[stepx][stepy] = a;
if (stepx == 0) {
if (sum(arr))
sum++;
return;
}
mk[a] = 1;
for (int i = 0; i < 10; i++) {
if (stepy < stepx)
dfs(arr, stepx, stepy + 1, i);
else
dfs(arr, stepx - 1, 0, i);
}
mk[a] = 0;
}
public static boolean sum(int[][] arr) {
for (int i = 2; i >= 0; i--) {
for (int j = 0; j <= i; j++) {
if (arr[i][j] > arr[i + 1][j] || arr[i][j] > arr[i + 1][j + 1]) {
return false;
}
}
}
return true;
}
}