美文网首页
算法学习-查找-二分查找

算法学习-查找-二分查找

作者: MacXin | 来源:发表于2018-02-08 12:23 被阅读0次

    (以下资料来自百度百科)

    查找过程:

        首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。

    算法要求:

        1.必须采用顺序存储结构。

        2.必须按关键字大小有序排列。

    比较次数:

        计算公式 a<log2(n)<b(a, b, n 都是正整数), 当顺序表有n个关键字时,查找失败时,至少比较a次关键字;查找成功时,最多比较关键字次数是b。

    算法复杂度:

        二分查找的基本思想是将n个元素分成大致相等的两部分,取a[n/2]与x做比较,如果x=a[n/2],则找到x,算法中止;如果xa[n/2],则只要在数组a的右半部搜索x.时间复杂度可以表示O(h)=O(log2n)

    补充:

        折半查找法也称为二分查找法,它充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(log n)完成搜索任务。

    javaScript用例:

    const Arr = [3, 5, 6, 7, 9, 12, 15];

    let index = -1, n = 0

    function binary(find, arr, low, high) {

      n++

      if (low <= high) {

        if (arr[low] == find) {

          index = low;

          return {index, n};

        }

        if (arr[high] == find) {

          index = high;

          return {index, n};

        }

        let mid = Math.ceil((high + low) / 2);

        if (arr[mid] == find) {

          index = mid

          return {index, n};

        } else if (arr[mid] > find) {

          return binary(find, arr, low, mid - 1);

        } else {

          return binary(find, arr, mid + 1, high);

        }

      }

      return {index, n};

    }

    binary(9, Arr, 0, Arr.length - 1);

    相关文章

      网友评论

          本文标题:算法学习-查找-二分查找

          本文链接:https://www.haomeiwen.com/subject/opqttftx.html