刷题之搜索旋转排序数组(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;
    }
};
相关推荐
退休倒计时8 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
洛水水11 小时前
【力扣100题】86.柱状图中最大的矩形
算法·leetcode·职场和发展
洛水水12 小时前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
洛水水13 小时前
【力扣100题】85.每日温度
算法·leetcode·职场和发展
Kurisu_红莉栖13 小时前
力扣56合并区间
算法·leetcode
开源Z13 小时前
LeetCode 135 · 分发糖果:两次扫描,先左后右取最大
算法·leetcode
退休倒计时13 小时前
【每日一题】LeetCode 19. 删除链表的倒数第 N 个结点 TypeScript
leetcode·链表·typescript
怪兽学LLM16 小时前
LeetCode 21 合并两个有序链表:彻底理解虚拟头节点(Dummy)套路
python·leetcode·链表
_日拱一卒17 小时前
LeetCode:22括号生成
算法·leetcode·职场和发展
洛水水18 小时前
【力扣100题】88.多数元素
数据结构·算法·leetcode