leetcode33.搜索旋转排序数组

整数数组 nums 按升序排列,数组中的值 互不相同

在传递给函数之前,nums 在预先未知的某个下标 k0 <= k < nums.length)上进行了 旋转 ,使数组变为 [nums[k], nums[k+1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]](下标 从 0 开始 计数)。例如, [0,1,2,4,5,6,7] 在下标 3 处经旋转后可能变为 [4,5,6,7,0,1,2]

给你 旋转后 的数组 nums 和一个整数 target ,如果 nums 中存在这个目标值 target ,则返回它的下标,否则返回 -1

你必须设计一个时间复杂度为 O(log n) 的算法解决此问题。

示例 1:

复制代码
输入:nums = [4,5,6,7,0,1,2], target = 0
输出:4

示例 2:

复制代码
输入:nums = [4,5,6,7,0,1,2], target = 3
输出:-1

示例 3:

复制代码
输入:nums = [1], target = 0
输出:-1

思路:直接先按照正常情况写代码 然后考虑异常情况;详情见下面代码:

java 复制代码
public int search(int[] nums, int target) {
        int low=0;
        int high=nums.length-1;
        int mid=low+(high-low)/2;
        while(low<=high){
            if(nums[mid]==target)
                return mid;
            else if(nums[mid]<target){
                // 异常情况:右边区间是有序的且右边最大值也<target
                if(nums[mid]<=nums[high]&&nums[high]<target)
                    high=mid-1;
                    // 正常应该到右边区间找
                else
                    low=mid+1;
            }

            else if(nums[mid]>target){
                //异常情况:左边区间有序且最小值也>target
                if(nums[mid]>=nums[low]&&nums[low]>target)
                    low=mid+1;
                    // 正常情况应该到左边区间找
                else
                    high=mid-1;
            }

            mid=low+(high-low)/2;
        }
        return -1;
    }
相关推荐
程序员阿鹏2 小时前
56.合并区间
java·数据结构·算法·leetcode
_OP_CHEN4 小时前
C++进阶:(三)深度解析二叉搜索树原理及实现
开发语言·数据结构·c++·二叉树·二叉搜索树·键值对
古译汉书4 小时前
Stm32江科大入门教程--各章节详细笔记---查阅传送门
数据结构·stm32·单片机·嵌入式硬件·算法
Jasmine_llq6 小时前
《P2656 采蘑菇》
算法·强连通分量·广度优先搜索(bfs)·tarjan 算法·图的缩点操作·有向无环图(dag)·最长路径
芥子沫6 小时前
《人工智能基础》[算法篇3]:决策树
人工智能·算法·决策树
mit6.8246 小时前
dfs|位运算
算法
苏纪云6 小时前
算法<C++>——双指针 | 滑动窗口
数据结构·c++·算法·双指针·滑动窗口
保持低旋律节奏6 小时前
算法——二叉树、dfs、bfs、适配器、队列练习
算法·深度优先·宽度优先
Y200309166 小时前
U-net 系列算法总结
人工智能·算法·目标跟踪