类似二分。

class Solution {
public:
    int findPeakElement(const vector<int> &num) {
        int size = num.size();
        int left = 0;
        int right = size - 1;
        while (left <= right) {
            int mid = (left + right) / 2;
            if ((mid == 0 || num[mid] > num[mid-1]) &&
                (mid == size - 1 || num[mid] > num[mid+1])) {
                return mid;
            }
            if (mid != 0 && num[mid] < num[mid-1]) {
                right = mid - 1;
            } else {
                left = mid + 1;
            }
        }
        return -1;
    }
};

  

相关文章:

  • 2021-06-24
  • 2021-11-22
  • 2021-10-11
  • 2022-01-02
  • 2021-12-06
  • 2021-12-20
  • 2021-09-08
猜你喜欢
  • 2022-03-04
  • 2021-09-29
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-01-18
相关资源
相似解决方案