Python中如何实现二分查找

本篇文章为大家展示了Python中如何实现二分查找,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

古蔺网站建设公司创新互联,古蔺网站设计制作,有大型网站制作公司丰富经验。已为古蔺成百上千家提供企业网站建设服务。企业网站搭建\成都外贸网站制作要多少钱,请找那个售后服务好的古蔺做网站的公司定做!

二分查找是一个用的非常多的查找算法,目的是从一个列表list里面,找到一个你想要的数,记做目标数据,返回这个数的索引,比如[5, 12, 3], 想找到12在哪,然后答案应该是1。直接的方法是从头开始,一个个比较,如果相等就返回,先拿5和12比, 不相等就继续下一个,12 = 12, 所以返回1,但是如果这个列表很大, 这样查找起来就比较慢,时间复杂度是O(n),而二分查找是一个比较高效的查找方法,数学里面学过二分法,我觉得道理是类似的。二分查找的时间复杂度是O(logn)。

二分查找的一般过程为先找到数组的中间数据,然后对比目标数据和中间数据,如果相等则返回中间数据,如果目标数据大于中间数据,则继续在列表的右边按照相同方法去寻找。否则在左边寻找;这里要注意的是,查找过程中的列表是经过排序以后的,所以这里比较的时候才会按大小去搜索。

下面是用Python实现二分查找的一个栗子



def binary_search(array, query_value):
   low, high = 0, len(array) - 1
   while low <= high:
       mid = low + (high - low) // 2
       mid_val = array[mid]
       if mid_val == query_value:
           return mid
       elif mid_val < query_value:
           low = mid + 1
       else:
           high = mid - 1
   return None


def main():
   array_1 = [1, 10, 20, 30, 180]
   print binary_search(array_1, 20)
   print "- * - " * 5
   array_2 = [2, 1, 3, 3, 5, 4, 1, 6]
   sorted_array = sorted(array_2)
   print "sorted_array : ", sorted_array
   print(binary_search(sorted_array, 5))


if __name__ == "__main__":
   main()

上述内容就是Python中如何实现二分查找,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


标题名称:Python中如何实现二分查找
网页路径:http://myzitong.com/article/igesdi.html