在旋转过的有序数组中寻找目标值(NC48/考察次数Top34/难度简单)

Posted 码农指南

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在旋转过的有序数组中寻找目标值(NC48/考察次数Top34/难度简单)相关的知识,希望对你有一定的参考价值。

描述:
给定一个整数数组nums,按升序排序,数组中的元素各不相同。
nums数组在旋转过后比如,数组[0,2,3,6,9,10]在下标2处旋转之后变为[6,9,10,0,2,3]
现在给定一个旋转后的数组nums和一个整数target,请查找这个数组是否存在target,如果存在,那么返回它的下标,如果不存在,返回-1

示例1
输入:
[6,9,10,0,2,3],10
返回值:
2
(题目来自牛客网)

用C++实现如下

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param nums int整型vector 
     * @param target int整型 
     * @return int整型
     */
    int search(vector<int>& nums, int target) {
        int n=nums.size();
//         //思路1,使用for循环进行处理
//         for(int i=0;i<n;++i){
//             if(nums[i]==target){
//                 return i;
//             }
//         }
//         return -1;
        //思路2,使用二分法进行求解
        int left=0;
        int right=nums.size()-1;
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]==target){                                  //说明nums[mid]不是要求的值
                return mid;
            }
            //有序数组经过旋转后,首先需要判断那一边是有序的
            if(nums[left]<nums[mid]){                               //左边有序递增;
                if(target>=nums[left]&&target<nums[mid]){
                    right=mid-1;
                }else{
                    left=mid+1;
                }
            }else{                                                  //右边有序递增;
                if(target>nums[mid]&&target<=nums[right]){
                    left=mid+1;
                }else{
                    right=mid-1;
                }
            }
        }
        return -1;
    }
};

纯手撕代码,如果觉得内容不错麻烦点个赞,后面陆续配上Top100算法题通俗易懂的讲解视频,可以花两个月时间完全掌握,进大厂不是梦,转行狗亲测!

以上是关于在旋转过的有序数组中寻找目标值(NC48/考察次数Top34/难度简单)的主要内容,如果未能解决你的问题,请参考以下文章

合并两个有序的数组(NC22/考察次数Top16/难度简单)

二分查找-II(NC105/考察次数Top66/难度中等)

二分查找-II(NC105/考察次数Top66/难度中等)

寻找第K大(NC88/考察次数Top7/难度中等)

寻找峰值(NC107/考察次数Top70/难度入门)

寻找峰值(NC107/考察次数Top70/难度入门)