leetcode 845
2021/11/22 6:10:06
本文主要是介绍leetcode 845,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
山峰数组指, 先严格递增, 再严格递减的数组. 现给到一个数组, 找到一个连续子数组, 使得该子数组是山峰数组, 输出最长的该子数组的长度.
要求只遍历一遍数组, 并且空间复杂度为O(1)
想了10分钟知道怎么写, 写了40分钟才debug没问题, 提交了5次前后, 我觉得我是一个sb.
class Solution: def longestMountain(self, arr: List[int]) -> int: result = 0 if len(arr) <= 2: return 0 result = 0 first_index = 0 pre_num = arr[0] left = 0 sign = 0 for i in range(1, len(arr)): # print(f"current index: {i}, sign = {sign}, left = {left}") current_num = arr[i] if pre_num < current_num: if sign == 0: pass else: tmp = i - 1 - left + 1 result = max(tmp, result) left = i - 1 sign = 0 elif pre_num == current_num: if sign == 0: left = i else: tmp = i - 1 - left + 1 result = max(tmp, result) # print(left, i, tmp) left = i sign = 0 else: if sign == 0: if left == i - 1: left = i else: sign = 1 tmp = i - left + 1 result = max(tmp, result) # print(left, i, tmp) else: tmp = i - left + 1 result = max(tmp, result) # print(left, i, tmp) pre_num = current_num return result
这篇关于leetcode 845的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-04el-table 开启定时器下,表格的选中状态会消失是什么原因-icode9专业技术文章分享
- 2024-10-03如何安装和初始化飞牛私有云 fnOS?-icode9专业技术文章分享
- 2024-10-03如何安装 App 并连接到飞牛 NAS?-icode9专业技术文章分享
- 2024-10-03如何安装飞牛 TV 并连接到影视服务器?-icode9专业技术文章分享
- 2024-10-03如何在PVE和ESXI上安装飞牛私有云 fnOS?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS安装系统异常情况处理-icode9专业技术文章分享
- 2024-10-03飞牛NAS如何创建存储空间?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS硬盘会自动休眠吗?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS如何安装飞牛影视和创建媒体库?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS如何为家人朋友开通影视账号?-icode9专业技术文章分享