博客
关于我
【10月打卡~Leetcode每日一题】845. 数组中的最长山脉(难度:中等){补昨日}
阅读量:256 次
发布时间:2019-03-01

本文共 973 字,大约阅读时间需要 3 分钟。

845. 数组中的最长山脉

在这里插入图片描述
思路:①先找数组中的“山峰”和“山谷”
②定义山峰到两边山谷的距离为山脉的距离
③遍历取最大的山脉

class Solution:    def longestMountain(self, A: List[int]) -> int:        len_ = len(A) - 1        if len_ < 2 :            return 0        peak,valley = list(),list()        if A[0] >= A[1]:            valley.append(1)        for i in range(1,len_):            if A[i]>A[i-1] and A[i]>A[i+1]:                peak.append(i)            elif A[i] == A[i-1] or A[i] == A[i+1]:                valley.append(i)            elif A[i] < A[i-1] and A[i]
= A[len_-1]: valley.append(len_-1) if peak: max_ = 0 for _ in peak: begin,end = 0,len_ for j in valley: if j<_: begin = j else: end = j break max_ = max(max_,end-begin+1) return max_ return 0

时间复杂度是根据数组情况分化的

最优时间复杂度O(n),最差时间复杂度O(n²)

转载地址:http://gqba.baihongyu.com/

你可能感兴趣的文章
Nexus指南中的更新强调集成和透明度的重要性
查看>>
Nexus指南已经发布
查看>>
Nexus(1):Nexus的安装与配置
查看>>
NFC技术:概述
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS
查看>>
nfs mount 故障 mount.nfs: access denied by server while mounting 10.0.100.208:/backup_usb
查看>>
NFS Server及Client配置与挂载详解
查看>>
NFS 服务配置篇
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS安装配置
查看>>
NFS服务器配置-服务启动与停止
查看>>
NFS的安装以及windows/linux挂载linux网络文件系统NFS
查看>>
NFS的常用挂载参数
查看>>
NFS网络文件系统
查看>>
NFS远程目录挂载
查看>>
nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
查看>>
NFV商用可行新华三vBRAS方案实践验证
查看>>
ng build --aot --prod生成文件报错
查看>>