leetcode Search in Rotated Sorted Array

class Solution {
public:
    int search(vector<int>& nums, int target) {
        if(nums.size()==1){if(target==nums[0]) return 0;else return -1;}
        if(nums.size()==2){if(target==nums[0]) return 0;else if(target==nums[1]) return 1;else return -1;}
        int changed=0;
        int pivot=0;
        for(int i=2;i<nums.size();i++){
            if((nums[i]-nums[i-1])*(nums[i-1]-nums[i-2])<0){
                changed=1;pivot=i;break;
            }
        }
        int l=nums.size();
        if(changed==0){return binarySearch(nums,target,0,l-1);}
        if(binarySearch(nums,target,0,pivot-1)!=-1){return binarySearch(nums,target,0,pivot-1);}
        else return binarySearch(nums,target,pivot,l-1);
    }
private:
    int binarySearch(vector<int> &nums,int target,int a,int b){
        if(nums.size()==0) return -1;
        if(a==b){
            if(target==nums[a]){return a;}
            else{return -1;}
        }
		if(b-a==1){
			if(target==nums[a]){return a;}
			else if(target==nums[b]){return b;}
			else return -1;
		}
        if(target==nums[(a+b)/2]){
            return (a+b)/2;
        }
        if(target>nums[(a+b)/2]){
            return binarySearch(nums,target,((a+b)/2)+1,b);
        }
        if(target<nums[(a+b)/2]){
            return binarySearch(nums,target,a,((a+b)/2)-1);
        }
    }
};
查找可采用二分,时间复杂度为logN,然而二分的前提为数组是有序的,此时需找出有序数列的断点,断点的左右序列都是有序的,分别进行二分查找即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值