class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left = 0, right = nums.size() - 1;
        while (left <= right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] == target) return mid;
            else if (nums[mid] < nums[right]) {
                if (nums[mid] < target && nums[right] >= target) left = mid + 1;
                else right = mid - 1;
            } else {
                if (nums[left] <= target && nums[mid] > target) right = mid - 1;
                else left = mid + 1;
            }
        }
        return -1;
    }
};

相关文章:

  • 2022-01-15
  • 2021-08-24
  • 2022-01-04
  • 2022-02-02
  • 2021-06-26
  • 2022-01-30
  • 2022-02-22
猜你喜欢
  • 2022-12-23
  • 2021-06-25
  • 2021-10-29
  • 2022-01-03
相关资源
相似解决方案