博客
关于我
【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/

你可能感兴趣的文章
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
NetScaler的常用配置
查看>>
netsh advfirewall
查看>>
NETSH WINSOCK RESET这条命令的含义和作用?
查看>>
Netty WebSocket客户端
查看>>
netty 主要组件+黏包半包+rpc框架+源码透析
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
Netty事件注册机制深入解析
查看>>
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>
Netty和Tomcat的区别已经性能对比
查看>>
Netty客户端断线重连实现及问题思考
查看>>
Netty工作笔记0006---NIO的Buffer说明
查看>>
Netty工作笔记0007---NIO的三大核心组件关系
查看>>
Netty工作笔记0011---Channel应用案例2
查看>>
Netty工作笔记0013---Channel应用案例4Copy图片
查看>>
Netty工作笔记0014---Buffer类型化和只读
查看>>
Netty工作笔记0020---Selectionkey在NIO体系
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>
Netty工作笔记0024---SelectionKey API
查看>>