潮童街拍

Java 二分法检索算法代码实现详解

 更新时间:2020-01-12 19:00:29   作者:佚名   我要评论(0)

一,二分法检索算法介绍


二分法检索(binary search)又称折半检索,二分法检索的基本思想是设字典中的元素从小到大有序地存放在数组(array)中。是最常用的搜索

一,二分法检索算法介绍

二分法检索(binary search)又称折半检索,二分法检索的基本思想是设字典中的元素从小到大有序地存放在数组(array)中。是最常用的搜索算法之一,这主要是由于其搜索时间短。

二,二分法检索算法思路

潮童街拍这种搜索使用分而治之方法,并且需要事先对数据集进行排序。

它将输入集合分为相等的两半,并且每次迭代都将目标元素与中间元素进行比较。

潮童街拍如果找到该元素,则搜索结束。否则,我们根据目标元素是小于还是大于中间元素,通过划分并选择适当的数组分区来继续寻找元素。

潮童街拍这就是为什么对Binary Search有一个排序的集合很重要的原因。

潮童街拍当firstIndex(我们的指针)经过lastIndex(最后一个元素)时,搜索将终止,这意味着我们已经搜索了整个数组,并且该元素不存在。

有两种方法可以实现此算法- 迭代和递归。

这里不应该是关于时间和空间这两个实现之间复杂的差异,虽然这不成立于所有语言。

三,二分法检索算法代码实现

迭代式

首先让我们看一下迭代方法:

public class SearchAlgorithms {
 /**
  *迭代方法
  * @param arr
  * @param elementToSearch
  * @return
  */
 public static int binarySearch(int arr[], int elementToSearch) {
 
  int firstIndex = 0;
  int lastIndex = arr.length - 1;
 
  // 终止条件(元素不存在)
  while(firstIndex <= lastIndex) {
   int middleIndex = (firstIndex + lastIndex) / 2;
   // 如果中间元素是我们的目标元素,那么返回它的索引
   if (arr[middleIndex] == elementToSearch) {
    return middleIndex;
   }
 
   // 如果中间的元素比较小
   // 将我们的指数指向中间+1,不考虑前半部分
   else if (arr[middleIndex] < elementToSearch)
    firstIndex = middleIndex + 1;
 
    // 如果中间的元素更大
    // 将我们的指数指向中间1,不考虑下半部分
   else if (arr[middleIndex] > elementToSearch)
    lastIndex = middleIndex - 1;
 
  }
  return -1;
 }
 /**
  * 用于打印结果
  * @param targetParameter
  * @param index
  */
 public static void print(int targetParameter, int index) {
  if (index == -1){
   System.out.println(targetParameter + " 未找到");
  }
  else {
   System.out.println(targetParameter + " 搜索结果为: " + index);
  }
 }
 //测试一下
 public static void main(String[] args) {
  int index = binarySearch(new int[]{89, 57, 91, 47, 95, 3, 27, 22, 67, 99}, 67);
  print(67, index);
 }
}

输出:

递归的

潮童街拍现在让我们看一下递归实现:

递归方法的区别在于,一旦获得新分区,我们便会调用方法本身。在迭代方法中,每当确定新分区时,我们都会修改第一个和最后一个元素,并在同一循环中重复该过程。

这里的另一个区别是递归调用被推入方法调用堆栈,并且每个递归调用占用一个空间单位。

潮童街拍我们可以像这样使用这种算法:

public class SearchAlgorithms {
 
 /**
  *递归方法
  * @param arr
  * @param elementToSearch
  * @return
  */
 public static int recursiveBinarySearch(int arr[], int firstElement, int lastElement, int elementToSearch) {
 
  // 结束条件
  if (lastElement >= firstElement) {
   int mid = firstElement + (lastElement - firstElement) / 2;
 
   // 如果中间元素是我们的目标元素,那么返回它的索引
   if (arr[mid] == elementToSearch)
    return mid;
 
   // 如果中间元素大于目标元素
   if (arr[mid] > elementToSearch)
    return recursiveBinarySearch(arr, firstElement, mid - 1, elementToSearch);
 
   return recursiveBinarySearch(arr, mid + 1, lastElement, elementToSearch);
  }
 
  return -1;
 }
 /**
  * 用于打印结果
  * @param targetParameter
  * @param index
  */
 public static void print(int targetParameter, int index) {
  if (index == -1){
   System.out.println(targetParameter + " 未找到");
  }
  else {
   System.out.println(targetParameter + " 搜索结果为: " + index);
  }
 }
 //测试一下
 public static void main(String[] args) {
  int index = recursiveBinarySearch(new int[]{3, 22, 27, 47, 57, 67, 89, 91, 95, 99}, 0, 10, 67);
  print(67, index);
 }
}

输出:

四,以算法时间复杂度和空间复杂度总结算法。 

时间复杂度

由于二进制搜索每次将其时间复杂度为O(log(N))时都会将数组分为两半。此时间复杂度是线性搜索O(N)时间复杂度的显着改进。

空间复杂度

此搜索仅需要一个空间单位即可存储要搜索的元素。因此,其空间复杂度为O(1)。

如果二分法检索是递归实现的,则需要将对该方法的调用存储在堆栈中。在最坏的情况下,这可能需要O(log(N))空间。

它是大多数用于搜索的库中最常用的搜索算法,二分法检索树也被许多存储排序数据的数据结构所使用。

该Arrays.binarySearch方法中的Java API也实现了二进制搜索哦。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

  • java 二分法算法的实例

潮童街拍相关的文章

  • Java 二分法检索算法代码实现详解

    Java 二分法检索算法代码实现详解

    一,二分法检索算法介绍 二分法检索(binary search)又称折半检索,二分法检索的基本思想是设字典中的元素从小到大有序地存放在数组(array)中。是最常用的搜索
    2020-01-12
  • Linux下PHP+Apache的26个必知的安全设置

    Linux下PHP+Apache的26个必知的安全设置

    PHP是一种开源服务器端脚本语言,应用很广泛。Apache web服务器提供了这种便利:通过HTTP或HTTPS协议,访问文件和内容。配置不当的服务器端脚本语言会带来各种各样
    2020-01-12
  • tensorflow的计算图总结

    tensorflow的计算图总结

    计算图 在 TensorFlow 中用计算图来表示计算任务。 计算图,是一种有向图,用来定义计算的结构,实际上就是一系列的函数的组合。 用图的方式,用户通过用一些简单
    2020-01-12
  • Python3.x+迅雷x 自动下载高分电影的实现方法

    Python3.x+迅雷x 自动下载高分电影的实现方法

    快要过年了,大家都在忙些什么呢?一到年底公司各种抢票,备年货,被这过年的气氛一烘,都归心似箭,哪还有心思上班啊。归心似箭=产出低下=一行代码十个错=无聊。于
    2020-01-12
  • 在微信小程序中渲染HTML内容3种解决方案及分析与问题解决

    在微信小程序中渲染HTML内容3种解决方案及分析与问题解决

    大部分Web应用的富文本内容都是以HTML字符串的形式存储的,通过HTML文档去展示HTML内容自然没有问题。但是,在微信小程序(下文简称为「小程序」)中,应当如何渲
    2020-01-12
  • ES2020 新特性(种草)

    ES2020 新特性(种草)

    这几年,Ecma TC39一年一次更新 ecmascript 规范标准,截止目前,以下特性已进入 finished 状态。现在带大家体验种草 ES2020 新特性。 一:Promise.allSettled
    2020-01-12
  • Python 实现递归法解决迷宫问题的示例代码

    Python 实现递归法解决迷宫问题的示例代码

    迷宫问题 问题描述: 迷宫可用方阵 [m, n] 表示,0 表示可通过,1 表示不能通过。若要求左上角 (0, 0) 进入,设计算法寻求一条能从右下角 (m-1, n-1) 出去的路径。
    2020-01-12
  • html2canvas属性和使用方法以及如何使用html2canvas将HTML内容写入Canvas生成图片

    html2canvas属性和使用方法以及如何使用html2canvas将HTML内容写入Canvas生成图片

    如何使用JS截取HTML页面为图片呢,下面为大家介绍一款JS截图插件html2canvas.js html2canvas.js 能够实现在用户浏览器端直接对整个或部分页面进行截屏。 html2can
    2020-01-12
  • golang并发编程的实现

    golang并发编程的实现

    go main函数的执行本身就是一个协程,当使用go关键字的时候,就会创建一个新的协程 channel channel 管道,用于在多个协程之间传递信号 无缓存管道 当对无
    2020-01-12
  • python opencv实现信用卡的数字识别

    python opencv实现信用卡的数字识别

    本项目利用python以及opencv实现信用卡的数字识别 前期准备 导入工具包 定义功能函数 模板图像处理 读取模板图像 cv2.imread(img) 灰度化处理 cv2
    2020-01-12

最新评论

神马电影网www.hmlhsw.com