Fork me on GitHub

栈的次序种类 -- 递归

栈的次序种类 虽然说是来看栈的次序种类 但这里没有用栈 而是用了递归 
在网上看到一道题附教学视频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);
	}
}
posted @ 2019-07-07 22:12  cznczai  阅读(230)  评论(0编辑  收藏  举报