【算法】剑指offer-二分查找

二分查找

剑指 Offer 53 - II. 0~n-1中缺失的数字

一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1之内。在范围0~n-1内的n个数字中有且只有一个数字不在该数组中,请找出这个数字。

二分查找

    public int missingNumber(int[] nums) {
        int left = 0, right = nums.length;
        int mid;
        while(left < right){
            mid = (right+left)>>>1;
            if(nums[mid] != mid) right = mid;
            else left = mid+1;
        }
        return left;
    }

剑指 Offer 53 - I. 在排序数组中查找数字 I

统计一个数字在排序数组中出现的次数。

输入: nums = [5,7,7,8,8,10], target = 8

输出: 2

二分查找,关键在于target+0.5和target-0.5之间的数字就是目标数字

    public int search(int[] nums, int target){
        return search1(nums, target+0.5) - search1(nums, target-0.5);
    }

    public int search1(int[] nums, double target) {
        int l = 0, r = nums.length-1;
        int mid;
        while(l <= r){
            mid = (l + r) >>> 1;
            if(nums[mid] > target) r = mid - 1;
            else if(nums[mid] < target) l = mid + 1;
        }
        return l;
    }

剑指 Offer 11. 旋转数组的最小数字

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一个旋转,该数组的最小值为1。

二分查找,找到不符合排序数组的规律的哪一个数字即起点

    public int minArray(int[] numbers) {
        int left = 0, right = numbers.length-1;
        int mid=0;
        while(left <= right){
            mid = (left+right)>>>1;
            if(numbers[mid] > numbers[right]) left=mid+1;
            else if(numbers[mid] < numbers[right]) right = mid;
            else right--;
        }
        return numbers[mid];
    }

你可能感兴趣的:(算法)