33. Search in Rotated Sorted Array

Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.

(i.e.,0 1 2 4 5 6 7might become4 5 6 7 0 1 2).

You are given a target value to search. If found in the array return its index, otherwise return -1.

You may assume no duplicate exists in the array.

解题方法

由連續區間去判斷: 畫圖!畫圖

public int search(int[] nums, int target) {
        //畫圖
        if(nums == null || nums.length == 0){
            return -1;
        }

        int start = 0;
        int end = nums.length - 1;
        while(start + 1 < end){
            int mid = start + (end -start) / 2;
            if(nums[mid] == target){
                return mid;
            }

            //左低右高
            //注意 <= && >=
            if(nums[start] < nums[mid]){
                if(nums[start] <= target && target < nums[mid]){
                    end = mid;
                }else{
                    start = mid;
                }
            }else{ //左高右低
                if(nums[mid] < target && target <= nums[end]){
                    start = mid; 
                }else{
                    end = mid;
                }
            }
        }

        if(nums[start] == target){
            return start;
        }else if(nums[end] == target){
            return end;
        }
        return -1;
    }

Follow up!

The array may contain duplicates.

解题方法

这个问题在面试中不会让实现完整程序

只需要举出能够最坏情况的数据是 [1,1,1,1... 1] 里有一个0即可。

在这种情况下是无法使用二分法的,复杂度是O(n)

因此写个for循环最坏也是O(n),那就写个for循环就好了

如果你觉得,不是每个情况都是最坏情况,你想用二分法解决不是最坏情况的情况,那你就写一个二分吧。

反正面试考的不是你在这个题上会不会用二分法。这个题的考点是你想不想得到最坏情况。

多增加兩個case


else if( nums[start] == nums[mid]){
   start++;
}else{
    end--;
}
    public boolean search(int[] nums, int target) {
        //MergeSort
        if(nums == null || nums.length == 0){
            return false;
        }

        int start = 0;
        int end = nums.length - 1;
        while(start + 1 < end){
            int mid = start + (end - start) / 2;
            if(target == nums[mid]){
                return true;
            }

            if(nums[start] < nums[mid]){
                if(target >= nums[start] && target < nums[mid]){
                    end = mid;
                }else{
                    start = mid;
                }
            }else if(nums[mid] < nums[end]){
                if(nums[mid] < target && nums[end] >= target){
                    start = mid;
                }else{
                    end = mid;//duplicates
                }
            }else if( nums[start] == nums[mid]){
                start++;
            }else{
                end--;
            }
        }

        if(target == nums[start]){
            return true;
        }
        if(target == nums[end]){
            return true;
        }

        return false;
    }

results matching ""

    No results matching ""