车厢调度问题-非_递归算法

本文探讨了如何解决车厢调度问题,不同于上一篇采用递归算法,这次使用非递归方法来生成所有可能的车厢序列。调度站遵循LIFO原则,要求输出序列在每个位置xi之后,编号小于xi的车厢必须是递减的。通过非递归算法,程序展示了不同车厢数量下的序列种类数量,例如n=4时有14种。
摘要由CSDN通过智能技术生成

问题描述:

假设停在铁路调度站入口处的车厢序列的编号依次为1,2,3……N。设计一个程序,求出所有由此输出的长度为N的车厢序列。

算法综述:

上一篇博文实现了解决车厢问题的递归算法。本文试图对N个车厢的全排列进行筛选,选出可能的序列。

必须声明,产生全排列的算法也有两种:递归和非递归,本文使用的是递归产生全排列。全排列的非递归算法后面再说。。。

调度站的本质是一个栈,LIFO决定了输出序列必须满足:

若以编号0,1,2,3...n-1的顺序进行调度,在一个输出序列x0,x1,x2......x(n-1)中,对于每个xi,序列x(i+1)......x(n-1)中,编号小于xi的车厢必须是递减的。


对每一个序列从后往前检查&

  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
车厢调度问题可以使用递归算法来解决。假设有n节车厢需要调度,每节车厢有一个编号编号从1到n。现在有一个长度为n的序列,表示车厢的初始顺序,需要通过一系列操作将其变为目标序列递归算法的思路是将问题分解为若干个子问题,每个子问题的规模比原问题小,然后将子问题的解合并起来得到原问题的解。在车厢调度问题中,我们可以将问题分解为以下两个子问题: 1. 将前k个车厢移到目标序列的前k个位置; 2. 将剩余的n-k个车厢移到目标序列的后n-k个位置; 对于第一个子问题,我们可以使用递归算法求解。假设当前需要将前k个车厢移到目标序列的前k个位置,我们可以找到当前需要移动的车厢x,然后将x移到目标序列的第k个位置,然后将前k-1个车厢移动到目标序列的前k-1个位置。对于第二个子问题,我们可以通过递归调用来求解。 递归算法的伪代码如下: ``` def solve(start, end): if start == end: return x = find_max(start, end) # 找到当前需要移动的车厢 move(x, end) # 将x移动到目标序列的第end个位置 solve(start, end-1) # 递归调用,处理前end-1个车厢 ``` 其中,`find_max(start, end)`函数用于找到当前需要移动的车厢,`move(x, end)`函数用于将车厢x移动到目标序列的第end个位置。 对于第二个子问题,我们可以通过递归调用`solve(k+1, n)`来求解,其中k表示目标序列前k个位置已经放置了前k个车厢。 完整的递归算法实现如下: ```python def find_max(start, end, seq): max_val = -1 max_idx = -1 for i in range(start, end+1): if seq[i] > max_val: max_val = seq[i] max_idx = i return max_idx def move(x, end, seq): for i in range(x, end): seq[i], seq[end] = seq[end], seq[i] end -= 1 def solve(start, end, seq): if start == end: return x = find_max(start, end, seq) move(x, end, seq) solve(start, end-1, seq) n = int(input()) seq = list(map(int, input().split())) solve(0, n-1, seq) print(*seq) ``` 其中,`find_max`函数用于找到当前需要移动的车厢,`move`函数用于将车厢移动到目标位置,`solve`函数用于递归处理子问题,`seq`表示当前的车厢序列。最后输出的`seq`即为最终的车厢序列
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值