algorithm - 数组中的二进制搜索

标签 algorithm arrays language-agnostic search binary-search

我如何只使用一个数组来实现二分查找?

最佳答案

确保您的数组已排序,因为这是二进制搜索的关键。

任何索引/随机访问数据结构都可以进行二进制搜索。因此,当您说“仅使用一个数组”时,我会说数组是采用二进制搜索的最基本/最常见的数据结构。

您可以递归(最简单)或迭代地执行此操作。二分搜索的时间复杂度为 O(log N),这比在 O(N) 处检查每个元素的线性搜索要快得多。以下是来自 Wikipedia: Binary Search Algorithm 的一些示例:

递归:

BinarySearch(A[0..N-1], value, low, high) {  
    if (high < low)  
        return -1 // not found  
    mid = low + ((high - low) / 2) 
    if (A[mid] > value)  
        return BinarySearch(A, value, low, mid-1)  
    else if (A[mid] < value)  
        return BinarySearch(A, value, mid+1, high)  
    else
       return mid // found
    }

迭代:

  BinarySearch(A[0..N-1], value) {
   low = 0
   high = N - 1
   while (low <= high) {
       mid = low + ((high - low) / 2)
       if (A[mid] > value)
           high = mid - 1
       else if (A[mid] < value)
           low = mid + 1
       else
           return mid // found
   }
   return -1 // not found
}

关于algorithm - 数组中的二进制搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/249392/

相关文章:

language-agnostic - 高流量、高安全的 Web API,什么语言?

language-agnostic - 我应该尽可能避免使用魔法字符串吗?

language-agnostic - 在 Vulkan 中更新顶点缓冲区的最普遍正确方法

java - 树/图遍历 : Find maximum value path

algorithm - 查找树结构中元素之间的关系,其中没有初始关系

javascript - QtQuick Item.children.indexOf() 不存在?

php 数组,foreach 键跳过一个值

c++ - 矩阵的 Dijkstra 算法

algorithm - 素因数计算的费马算法

python - 接收 "ValueError: setting an array element with a sequence."