如果你已经没有台阶了,那么你就到达了终点;如果你还有1个台阶,下一步只能是1级;如果前方还有更多的台阶,下一步可以是1或2级,所以递归变得非常简单:
void makeSteps(List<Integer> prevSteps, int s) {
if (s == 0) {
System.out.println(prevSteps);
} else {
List<Integer> n1 = new ArrayList<>(prevSteps);
n1.add(1);
makeSteps(n1, s - 1);
if (s > 1) {
List<Integer> n2 = new ArrayList<>(prevSteps);
n2.add(2);
makeSteps(n2, s - 2);
}
}
}
prevSteps
表示之前的路径,s
表示剩余的楼梯数。要打印出n级楼梯的所有可能的走法,请调用:
makeSteps(new ArrayList<>(), n);
非常容易将此代码重构为更通用的形式,其中可能的步长不仅可以是1或2,还可以是任何小于
maxStep
的数字。
void makeSteps(List<Integer> prevSteps, int s, int maxStep) {
if (s == 0) {
System.out.println(prevSteps);
} else {
for (int step = 1; step <= Math.min(maxStep, s); step++) {
List<Integer> newSteps = new ArrayList<>(prevSteps);
newSteps.add(step);
makeSteps(newSteps, s - step, maxStep);
}
}
}
为了得到相同的结果,请使用第三个参数调用它:
makeSteps(new ArrayList<>(), 4, 2);