刷题之搜索旋转排序数组(leetcode)

搜索旋转排序数组

时间复杂度O(n)的版本:

直接把数组分为有序的两个数组,然后分别进行双指针查找。

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int l=0;
        int r=nums.size()-1;

        while(l<nums.size()-1&&nums[l+1]>nums[l])
        {
            l++;
        }
        int mid=l;
        l=0;
        r=nums.size()-1;

        int left=find(nums,l,mid,target);
        int right=find(nums,mid+1,r,target);
        if(left!=-1)
            return left;
        if(right!=-1)
            return right;
        return -1;
    }
    int  find(vector<int>&nums,int l,int r,int target)
    {
        while(l<=r)
        {
            int mid=(r-l)/2+l;
            if(nums[mid]==target)
                return mid;
            else if(nums[mid]<target)
            {
                l=mid+1;
            }else
            {
                r=mid-1;
            }
        }
        return -1;
    }
};

时间复杂度为O(logn)的版本,先区分出有序的一部分,看target是否在这部分,否则再从无序到那部分中再区分有序的部分进行查找。

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int l=0;
        int r=nums.size()-1;

        while(l<=r)
        {
            int mid=(r-l)/2+l;
            if(nums[mid]==target)
                return mid;
            //如果左边(包括mid)是有序的
            if(nums[mid]>=nums[l])
            {
                //target在mid左边部分
                if(target>=nums[l]&&target<nums[mid])
                {
                    r=mid-1;
                }else//target不在左边部分
                {
                    
                    l=mid+1;
                }
            }
            else//右边部分是有序的
            {
                //target在mid右边部分
                if(target<=nums[r]&&target>nums[mid])
                {
                    l=mid+1;
                }else//target不在右边部分
                {
                    r=mid-1;
                }

            }
        }
        return -1;
    }
};
相关推荐
枫景Maple4 小时前
LeetCode 2297. 跳跃游戏 VIII(中等)
算法·leetcode
緈福的街口8 小时前
【leetcode】3. 无重复字符的最长子串
算法·leetcode·职场和发展
小刘不想改BUG11 小时前
LeetCode 70 爬楼梯(Java)
java·算法·leetcode
sz66cm13 小时前
LeetCode刷题 -- 542. 01矩阵 基于 DFS 更新优化的多源最短路径实现
leetcode·矩阵·深度优先
爱coding的橙子15 小时前
每日算法刷题Day24 6.6:leetcode二分答案2道题,用时1h(下次计时20min没写出来直接看题解,节省时间)
java·算法·leetcode
慢慢慢时光15 小时前
leetcode sql50题
算法·leetcode·职场和发展
pay顿15 小时前
力扣LeetBook数组和字符串--二维数组
算法·leetcode
岁忧15 小时前
(nice!!!)(LeetCode每日一题)2434. 使用机器人打印字典序最小的字符串(贪心+栈)
java·c++·算法·leetcode·职场和发展·go
Tisfy15 小时前
LeetCode 2434.使用机器人打印字典序最小的字符串:贪心(栈)——清晰题解
leetcode·机器人·字符串·题解·贪心·