刷题之搜索旋转排序数组(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;
    }
};
相关推荐
阿Y加油吧3 小时前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
不要秃头的小孩3 小时前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
We་ct4 小时前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
py有趣4 小时前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
py有趣6 小时前
力扣热门100题之编辑距离
数据结构·算法·leetcode
水木流年追梦7 小时前
CodeTop 热门题目汇总hot300题
算法·leetcode·职场和发展
f3iiish8 小时前
2078. 两栋颜色不同且距离最远的房子 力扣
算法·leetcode
sheeta19989 小时前
LeetCode 每日一题笔记 日期:2026.04.21 题目:1722. 执行交换操作后的最小汉明距离
笔记·算法·leetcode
玛丽莲茼蒿10 小时前
Leetcode hot100 买卖股票的最佳时机【简单】
算法·leetcode·职场和发展
阿Y加油吧10 小时前
两道 LeetCode 题的复盘笔记:从「只会暴力」到「懂优化」
笔记·算法·leetcode