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

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

查找过程:

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

算法要求:

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • 原文出处:http://www.cnblogs.com/maybe2030/p/4715035.html引文出处:...
    明教de教主阅读 13,009评论 0 7
  • 查找和排序都是程序设计中经常用到的算法。查找相对而言较为简单,不外乎顺序查找、二分查找、哈希表查找和二叉排序树查找...
    eagleRock阅读 10,931评论 0 14
  • 早起做好早餐。热了南瓜饼蒸了红薯,煮了红茶牛奶,还给阗阗煎了鸡蛋和土豆片。还做了煎鱼。呵呵,丰盛的早餐让我的味蕾...
    丽萍在这阅读 1,004评论 1 3
  • 当初父母给他取“李寻欢”这个名字时,是希望他将来能快乐。 但父母不知,当一个人需要寻欢时,说明他并不快乐。 或许这...
    Queen_Z阅读 4,140评论 0 1

友情链接更多精彩内容