Java中Binary Search如何实现

avatar
作者
筋斗云
阅读量:0

在Java中,可以使用递归或迭代的方式实现二分搜索算法。以下是一个使用迭代方式实现的示例代码:

public static int binarySearch(int[] arr, int target) {     int left = 0;     int right = arr.length - 1;      while (left <= right) {         int mid = left + (right - left) / 2;          if (arr[mid] == target) {             return mid;         } else if (arr[mid] < target) {             left = mid + 1;         } else {             right = mid - 1;         }     }      return -1; // 如果找不到目标元素,则返回-1 } 

在这段代码中,arr是一个已经排序的数组,target是要查找的目标元素。在每一次迭代中,我们计算中间元素的索引mid,然后根据arr[mid]target的大小关系来更新leftright的值,直到找到目标元素或者left > right为止。如果找到目标元素,则返回它的索引,否则返回-1表示未找到。

另外,也可以使用递归的方式实现二分搜索算法,递归的实现方式如下:

public static int binarySearchRecursive(int[] arr, int target) {     return binarySearchRecursive(arr, target, 0, arr.length - 1); }  private static int binarySearchRecursive(int[] arr, int target, int left, int right) {     if (left > right) {         return -1;     }      int mid = left + (right - left) / 2;      if (arr[mid] == target) {         return mid;     } else if (arr[mid] < target) {         return binarySearchRecursive(arr, target, mid + 1, right);     } else {         return binarySearchRecursive(arr, target, left, mid - 1);     } } 

在这段代码中,binarySearchRecursive方法是一个重载方法,它接受一个数组arr和目标元素target作为参数,并调用了另一个私有方法binarySearchRecursive来执行实际的搜索。在私有方法中,我们使用递归的方式来执行二分搜索,直到找到目标元素或者left > right为止。如果找到目标元素,则返回它的索引,否则返回-1表示未找到。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!