访问量: 10 次浏览
假设我们有一个名为nums的数字列表。我们必须查找最长子列表的长度,使得(最小长度为3)其值严格递增然后递减。
因此,如果输入是nums = [7,1,3,5,2,0],则输出将是5,因为子列表[2,4,6,3,1]是严格递增然后递减的。
为了解决这个问题,我们将遵循以下步骤:
res:= -无穷大n-2时,进行如下操作st:= ilinc:= 0,ldec:= 0n-1且a [i] < a [i + 1]时linc:= linc + 1i + 1n-1且a [i]> a [i + 1]时ldec:= ldec + 1i + 1linc > 0且ldec > 0,则res:= res和(i-st + 1)的最大值n-1且a [i]与a [i + 1]相同时i + 1res >= 0,则返回res,否则返回0让我们看一下以下实现以更好地理解
class Solution:
def solve(self, a):
i, n, res = 0, len(a), float("-inf")
while i < n - 2:
st = i
linc, ldec = 0, 0
while i < n - 1 and a[i] < a[i + 1]:
linc += 1
i += 1
while i < n - 1 and a[i] > a[i + 1]:
ldec += 1
i += 1
if linc > 0 and ldec > 0:
res = max(res, i - st + 1)
while i < n - 1 and a[i] == a[i + 1]:
i += 1
return res if res >= 0 else 0
ob = Solution()
nums = [8, 2, 4, 6, 3, 1]
print(ob.solve(nums))
[[8, 2, 4, 6, 3, 1]]
5