[leetcode]山脉数组的峰顶索引

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u014286840/article/details/84347212

852. 山脉数组的峰顶索引

我们把符合下列属性的数组 A 称作山脉:

  • A.length >= 3
  • 存在 0 < i < A.length - 1 使得A[0] < A[1] < … A[i-1] < A[i] > A[i+1] >
    … > A[A.length - 1]

给定一个确定为山脉的数组,返回任何满足 A[0] < A[1] < … A[i-1] < A[i] > A[i+1] > … > A[A.length - 1] 的 i 的值。

示例 1:

输入:[0,1,0]
输出:1

示例 2:

输入:[0,2,1,0]
输出:1

提示:

  1. 3 <= A.length <= 10000
  2. 0 <= A[i] <= 10^6
  3. A 是如上定义的山脉

C++解法:

class Solution {
public:
    int peakIndexInMountainArray(vector<int>& A) {
        for (int i = 1; i < A.size(); ++i)
        {
            if (A[0] > A[1])
            {
                if (A[i-1] < A[i])
                {
                    return i - 1;
                }
            }
            else
            {
                if (A[i - 1] > A[i])
                {
                    return i - 1;
                }
            }
        }
    }
};

猜你喜欢

转载自blog.csdn.net/u014286840/article/details/84347212