栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

山峰数组的顶部

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

山峰数组的顶部

1 问题

给定由整数组成的山峰数组 arr ,返回任何满足 arr[0] < arr[1] < ... arr[i - 1] < arr[i] > arr[i + 1] > ... > arr[arr.length - 1] 的下标 i ,即山峰顶部。

示例 1:

输入:arr = [0,1,0]

输出:1

示例 2:

输入:arr = [1,3,5,4,2]

输出:2

2 方法

  1. 循环遍历
    题目给的是一个山峰数组,所以是先递增再递减
    思路一:
    对数组进行遍历,如果遍历到的那个元素比下一个元素大,则这个元素。

  2. 二分法查找
    在山峰数组中,因为是先递增再递减,要使用二分查找方法的话
    假设满足题目要求所要得元素下标为mid,那么就满足在下标i这个时候arr[i]mid时,arr[i]>arr[i+1]也是一直成立的。
    这样就有一个思路:
    定义左边left=0,右边right=len(arr)-2,ans = 0。
    这样定义是防止特殊数组的出现,如只有三个数的数组,这个时候就取中间 。mid = (left+right)/2
    如果arr[mid]>arr[mid+1],则定义ans = mid,此时right向左边移动一位,如果arr[mid]代码如下:

  3. 第三种:使用python内部函数

直接使用max(arr)求出最大值,再arr.index(max(arr))直接求出最大值下标。

            山峰数组代码

//循环遍历查找最大值
arr = [12, 26, 48, 49, 56, 79, 50, 44, 32, 11]
n = len(arr)
ans = 0
for i in range(n):
if arr[i] > arr[i + 1]:
       ans = i
break
print(ans)
//使用二分法查找
arr = [12, 26, 48, 49, 56, 79, 50, 44, 32, 11]
n = len(arr)
left, right, ans = 1, n - 2, 0

while left <= right:
   mid = (left + right) // 2
if arr[mid] > arr[mid + 1]:
       ans = mid
       right = mid - 1
else:
       left = mid + 1
print(ans)
//使用python内部函数直接求
arr = [12, 26, 48, 49, 56, 79, 50, 44, 32, 11]
print(arr.index(max(arr)))

4 结语

针对山峰数组问题,提出了循环遍历,二分法,python内部函数等方法解决问题,对于二分法要注意的是,每一次进行二分法查找之前,先对定义的指针进行移动。

实习编辑:李欣容

稿件来源:深度学习与文旅应用实验室(DLETA)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/348589.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号