2024-09-01
课程学习
00

https://blog.csdn.net/darkrabbit/article/details/89409548

(1) 出栈序列共有多少种可能?

(2) 求出所有出栈(入栈)序列。

(3) 给出一个出栈序列,问栈的容量最少需要多少?

(4) 给出一个(或多个)出栈序列,问此序列是不是(哪一个序列不是)原序列混洗得到的?

在这里插入图片描述

python

题目描述

给定一个正整数N代表火车数量,0<N<10,接下来输入火车入站的序列,一共N辆火车,每辆火车以数字1-9编号,火车站只有一个方向进出,同时停靠在火车站的列车中,只有后进站的出站了,先进站的才能出站。

要求输出所有火车出站的方案,以字典序排序输出。

python
while True: try: n = int(input()) trains = [ str(1+i) for i in range(n)] res = [] def rec_trains(cur_idx, in_trains, out_trains): # 如果原始火车列表的最后一个元素已经进站,此时只能出站,将入站列表中的火车倒序加入出站火车中 if trains[-1] in in_trains: res.append(' '.join(out_trains + in_trains[::-1])) return # 如果进站列表为空,此时只能进站,进站列表加上当前火车,出站列表不变 elif in_trains == []: rec_trains(cur_idx + 1, in_trains + [trains[cur_idx]], out_trains) # 否则,就既有可能进站也有可能出站 else: # 出站,当前火车索引不变,进站火车列表减去最后一个元素,出站列表加上进站列表刚刚出站的火车 rec_trains(cur_idx, in_trains[:-1], out_trains + [in_trains[-1]]) # 进站,当前火车索引加1,进站列表加上当前火车,出站列表不变 rec_trains(cur_idx + 1, in_trains + [trains[cur_idx]], out_trains) rec_trains(0, [], []) res.sort() print(len(res)) except: break
如果对你有用的话,可以打赏哦
打赏
ali pay
wechat pay

本文作者:Dong

本文链接:

版权声明:本博客所有文章除特别声明外,均采用 CC BY-NC。本作品采用《知识共享署名-非商业性使用 4.0 国际许可协议》进行许可。您可以在非商业用途下自由转载和修改,但必须注明出处并提供原作者链接。 许可协议。转载请注明出处!