LeetCode--704. Binary Search

二分查找的两种写法:

1、循环:

class Solution {
    public int search(int[] nums, int target) {
        if(nums == null) {
            return -1;
        }
        int lo = 0;
        int hi = nums.length - 1;
        while(lo <= hi) {
            int mid = (lo + hi) / 2;
            if(target > nums[mid]) {
                lo = mid + 1;
            } else if(target < nums[mid]) {
                hi = mid - 1;
            } else {
                return mid;
            }
        }
        return -1;
    }
}

2、递归:

class Solution {
    public int search(int[] nums, int target) {
        return binarySearch(nums, 0, nums.length - 1, target);
    }
    private int binarySearch(int[] nums, int lo, int hi, int target) {
        if(lo > hi) return -1;
        int mid = (lo + hi) / 2;
        return target > nums[mid] ? binarySearch(nums, mid + 1, hi, target) :
                    target < nums[mid] ? binarySearch(nums, lo, mid - 1, target) : mid;
    }
}

 

相关文章:

  • 2021-08-09
  • 2021-12-28
  • 2021-11-19
  • 2021-07-06
  • 2021-06-26
  • 2021-09-18
  • 2021-06-16
  • 2022-01-16
猜你喜欢
  • 2021-10-19
  • 2021-08-04
  • 2021-11-23
  • 2021-11-29
  • 2022-01-09
相关资源
相似解决方案