zoukankan      html  css  js  c++  java
  • 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));
        }
    }
  • 相关阅读:
    (兼容)IE9 以下版本浏览器兼容HTML5的方法
    使用ORACLE 中ROWNUM方法实现数据库分批获取
    更新上传到github的代码
    Spring-AOP
    C++结构体的应用_YCOJ
    基本类型数据封装
    sessionStorage 封装
    Vue国际化四 -- 本地缓存
    Vue国际化三【在下拉框中使用】
    Vue国际化二 【在表格中的使用】
  • 原文地址:https://www.cnblogs.com/mayang2465/p/11730155.html
Copyright © 2011-2022 走看看