• 33. 搜索旋转排序数组


    题目描述:

      假设按照升序排序的数组在预先未知的某个点上进行了旋转。

      ( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。

      搜索一个给定的目标值,如果数组中存在这个目标值,则返回它的索引,否则返回 -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

     题解:

        本题的数组可分为两种情况,一种是前长后短,如:“[6,7,8,9,0,1,2]”,
        另外一种情况是前短后长,如:[8,9,0,1,2,3,4]

          

    package array;
    
    public class L33 {
        public static int search(int[] nums, int target) {
           return  searchIndex2(nums,target,0,nums.length-1);
        }
        //针对于当前问题的查找算法
        public static int searchIndex2(int[] nums, int target,int start,int end){
            while(start <= end){
                if(nums[(start+end)/2] == target){
                    return (start+end)/2;
                }
                if(nums[(start+end)/2] >= nums[start]){//前长后短的模式--情况1
                    if(nums[(start+end)/2] > target && (nums[start]<=target)){ //图中颜色加深区域
                        return searchIndex2(nums, target,start,(start+end)/2-1);
                    }else {
                        return searchIndex2(nums, target,(start+end)/2+1,end);
                    }
                }else{//前短后长的模式情况2
                    if(nums[(start+end)/2] < target && (nums[end]>=target)){ //图中颜色加深区域
                        return searchIndex2(nums, target, (start+end)/2+1,end);
                    }else {
                        return searchIndex2(nums, target,start,(start+end)/2-1);
                    }
                }
            }
            return -1;
        }
        //二分法查找的demo-本题没有用到
        public static int searchIndex(int[] nums, int target,int start,int end){
            while(start <= end){
                if(nums[(start+end)/2] == target){
                    return (start+end)/2;
                }else if(nums[(start+end)/2] > target){
                    end = (start+end)/2-1;
                    return searchIndex(nums, target,start,end);
                }else {
                    start =  (start+end)/2+;
                    return searchIndex(nums, target,start,end);
                }
            }
            return -1;
        }
        public static void main(String[] args) {
            int[] nums = new int[]{4, 5, 6, 7, 0, 1, 2};
            System.out.println(search(nums,0));
        }
    }
  • 相关阅读:
    HTML5印章绘制电子签章图片,中文英文椭圆章、中文英文椭圆印章
    送别2019,期待2020!
    [系列] Go
    当查询的数据来自多个数据源,有哪些好的分页策略?
    究竟什么样的开发流程是规范的?
    Git 分支设计规范
    API 接口设计规范
    一线技术管理者究竟在管什么事?
    一个人被提拔,不仅仅是能力,而是信任
    [系列] Go 如何解析 JSON 数据?
  • 原文地址:https://www.cnblogs.com/mayang2465/p/11730155.html
Copyright © 2020-2023  润新知