在Python中查找字典顺序最大的山脉列表的程序
假设我们有三个正数,比如n、lower和upper。我们必须找到一个列表,它的长度为n,且严格递增,接着是严格递减,所有的数字都在区间[lower和upper]内(两端都包括)。并且每个递增和递减的部分都不应为空。我们必须找到可能的字典序最大的这样的列表,如果不可能,则返回空列表。
因此,如果输入为n = 5 lower = 3 upper = 7,则输出将是[6,7,6,5,4],如果仔细观察,[7,6,5,4,3]是无效的,因为严格递增部分不应为空。
为了解决这个问题,我们将按照以下步骤操作:
- 如果n大于2*(upper-lower)+1,则
- 返回空列表
- c:= upper – lower
- d:= 1
- 如果c
- d:= n-c-1
- 如果d等于0,则
- d:= 1
- f:= 从(upper-d)到(upper-1)的新列表
- g:= 从(upper-n+d-1)到upper的新列表
- 连接f和g并返回
例子
让我们看以下实现以获得更好的理解