栈的次序种类 虽然说是来看栈的次序种类 但这里没有用栈 而是用了递归 在网上看到一道题附教学视频https://www.bilibili.com/video/av36899189/?p=2 题目 X星球特别讲究秩序,所有道路都是单行线。 一个甲壳虫车队,共16辆车,按照编号先后发车,夹在其它车流中,缓缓前行。 路边有个死胡同,只能容一辆车通过,是临时的检查站,如图所示。 X星球太死板,要求每辆路过的车必须进入检查站,也可能不检查就放行,也可能仔细 检查。 如果车辆进入检查站和离开的次序可以任意交错。那么,该车队再次上路后,可能的次序 有多少种? 为了方便起见,假设检查站可容纳任意数量的汽车。 显然,如果车队只有1辆车,可能次序1种;2辆车可能次序2种;3辆车可能次序5种。 代码
import java.util.*; public class problem { public int count = 0; public void caroutandin(int A, int B) { if (A == 0 && B == 0) { count++; } if (A > 0) caroutandin(A - 1, B + 1); if (B > 0) caroutandin(A, B - 1); } public static void main(String[] args) { problem p = new problem(); Scanner input = new Scanner(System.in); int n = input.nextInt(); p.caroutandin(n, 0); System.out.println(p.count); } }
第二种解法跟一种差不多 但在执行过程中有一些没必要算的结果会跳掉 省去一些时间
这里的代码跟视频有点差别
import java.util.*; public class problem { public int count = 0; public void f(int left, int stop) { if (left == 0 && stop == 0) { count++; } if (left == 0) {// 因为左边没有 只能把右边所有输出 而输出只有一种解 count++; } else if (stop == 0) {// 同上 f(left - 1, 1); } else { f(left - 1, stop + 1); f(left, stop - 1); } } public static void main(String[] args) { problem p = new problem(); p.f(16, 0); System.out.println(p.count); } }