Python求数组局部最大值的实例-创新互联

求数组局部大值

在海城等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站设计、网站建设 网站设计制作按需定制开发,公司网站建设,企业网站建设,成都品牌网站建设,网络营销推广,外贸网站制作,海城网站建设费用合理。

给定一个无重复元素的数组A[0…N-1],求找到一个该数组的局部大值。规定:在数组边界外的值无穷小。即:A[0]>A[-1],A[N-1] >A[N]。

显然,遍历一遍可以找到全局大值,而全局大值显然是局部大值。

可否有更快的办法?

算法描述

使用索引left、right分别指向数组首尾。

求中点 mid = ( left + right ) / 2

A[mid]>A[mid+1],丢弃后半段:right=mid

A[mid+1]>A[mid],丢弃前半段:left=mid+1

递归直至left==right

时间复杂度为O(logN)。

Python代码

def local_maximum(li):
  if li is None:
    return
  left = 0
  right = len(li) - 1
  while left < right:
    mid = int((left + right) / 2)
    if li[mid] > li[mid + 1]:
      right = mid
    else:
      left = mid + 1
  return li[left]


if __name__ == '__main__':
  li = [1, 5, 2, 3, 4, 0]
  result = local_maximum(li)
  print(result)

名称栏目:Python求数组局部最大值的实例-创新互联
浏览地址:http://bzwzjz.com/article/jogoi.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 网站建设 重庆网站建设 达州网站设计 成都网站建设公司 成都企业网站设计 定制网站建设多少钱 高端网站设计 手机网站制作设计 成都网站制作 成都网站建设流程 教育网站设计方案 网站制作公司 定制级高端网站建设 高端网站设计 阿坝网站设计 成都定制网站建设 上市集团网站建设 成都网站建设 响应式网站设计 网站制作报价 响应式网站设计 成都网站设计