刷题之搜索旋转排序数组(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;
    }
};
相关推荐
im_AMBER6 小时前
Leetcode 102 反转链表
数据结构·c++·学习·算法·leetcode·链表
AlenTech7 小时前
200. 岛屿数量 - 力扣(LeetCode)
算法·leetcode·职场和发展
散峰而望8 小时前
【算法竞赛】栈和 stack
开发语言·数据结构·c++·算法·leetcode·github·推荐算法
老鼠只爱大米9 小时前
LeetCode算法题详解 438:找到字符串中所有字母异位词
算法·leetcode·双指针·字符串匹配·字母异位词·滑动窗口算法
AlenTech9 小时前
198. 打家劫舍 - 力扣(LeetCode)
算法·leetcode·职场和发展
重生之后端学习10 小时前
21. 合并两个有序链表
java·算法·leetcode·链表·职场和发展
源代码•宸10 小时前
Leetcode—1266. 访问所有点的最小时间【简单】
开发语言·后端·算法·leetcode·职场和发展·golang
YuTaoShao10 小时前
【LeetCode 每日一题】712. 两个字符串的最小ASCII删除和——(解法一)记忆化搜索
算法·leetcode·职场和发展
圣保罗的大教堂11 小时前
leetcode 1266. 访问所有点的最小时间 简单
leetcode
源代码•宸11 小时前
Leetcode—85. 最大矩形【困难】
经验分享·算法·leetcode·职场和发展·golang·单调栈