小明最近喜欢搭数字积木。一共有10块积木,每个积木上有一个数字,0~9。
搭积木规则: 每个积木放到其它两个积木的上面,并且一定比下面的两个积木数字小。 最后搭成4层的金字塔形,必须用完所有的积木。 下面是两种合格的搭法: 0 1 2 3 4 5 6 7 8 9 0 3 1 7 5 2 9 8 6 4 请你计算这样的搭法一共有多少种?
public class Main { static int count; public static void main(String[] args) { f("0123456789".toCharArray(), 0); System.out.println(count); } private static boolean g(char[] a) { if(a[0] < a[1] && a[0] < a[2] && a[1] < a[3] && a[1] < a[4] && a[2] < a[4] && a[2] < a[5] && a[3] < a[6] && a[3] < a[7] && a[4] < a[7] && a[4] < a[8] && a[5] < a[8] && a[5] < a[9]) return true; return false; } public static void f(char[] a, int step) { if(step == a.length - 1) { if(g(a)) { count ++; return; } else { return; } } for(int i = step; i < a.length; i ++) { { char t = a[step]; a[step] = a[i]; a[i] = t; } f(a, step + 1); { char t = a[step]; a[step] = a[i]; a[i] = t; } } } }