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

2018-02-08  本文已影响0人  MacXin

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

查找过程:

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

算法要求:

    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);

上一篇下一篇

猜你喜欢

热点阅读