1.2二分法

  • 1.算法
    • 1.1排序算法的稳定性
    • 1.2二分法
    • 1.3归并排序法
    • 1.4归并排序法
    • 1.5冒泡排序法
    • 1.6选择排序算法
    • 1.7插入排序法
  • 2.树和树算法
    • 2.1树的概念
    • 2.2二叉树
    • 2.3树的遍历
  • Published with GitBook

1.2二分法

二分法查找

适用场景:在已经排序好的数据里,如顺序表里查找

操作思路

通过列表的首尾位置索引后相加,除以二,向下取整(“//”)。判断出二分法后的索引位置是否是查找的目标,若不是就根据目标大小与当前索引位置比较,判断使向前还是向后索引,如此循环。

  • 注意:循环退出的条件

1.递归法实现的代码:

1.2二分法_第1张图片

 

 

2.非递归法实现的代码:

1.2二分法_第2张图片

 

 

时间复杂度

  • 最优时间复杂度:O(1)
  • 最坏时间复杂度:O(logn)

 

你可能感兴趣的:(1.2二分法)