class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param nums int整型vector * @param target int整型 * @return int整型 */ int search(vector<int>& nums, int target) { // write code here int res; int left = 0, right = nums.size() - 1; while(left < right ) { int mid = (left + right) / 2; if(nums[mid] > nums[left]) { // 如果左半边有序 if(nums[mid] >= target) // 在左半边有序的情况下,target存在于左半边 right = mid; else // 在左半边有序的情况下,target存在于右半边 left = mid + 1; } else { // 如果左半边没有序、那么右半边一定有序 if(target > nums[mid]) // 左半边没有序情况下,target存在于右半边 left = mid + 1; else right = mid; } } // cout << nums[left]; if(nums[left] == target) return left; return -1; } };