zoukankan      html  css  js  c++  java
  • python实现二分法

    前言:

    二分法主要是用来查找位置的id,每次能够排除掉一半的数据,查找的效率非常高,但是局限性比较大。 必须是有序序列才可以使用二分查找。

    • 原理

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

    • 代码如下:

      # encoding:utf-8
      def BinarSearch(lst,value):
          """
          python 实现二分查找
          """
          first = 0
          last = len(lst)-1while first < last:
              mid_value = int((first+last)//2)
              if lst[mid_value] < value:
                  first = mid_value +1
              elif lst[mid_value] > value:
                  last = mid_value - 1
              else:
                  return mid_value
          return False
      ​
      ​
      if __name__ == '__main__':
          lst = [1, 3, 4, 8, 22, 65, 73]
          print(lst)
          index = BinarSearch(lst, 8)
          print(index)

       

    •  

  • 相关阅读:
    并行计算上机代码
    BZOJ 5170: Fable
    ANTLR4 实验总结
    ANTLR4将BF翻译成CPP
    BF语言学习
    ANTLR4将JSON翻译成XML
    ANTLR4加载csv数据
    语法分析树监听器和访问器
    数据库数据类型总结
    java介绍
  • 原文地址:https://www.cnblogs.com/shierlou-123/p/11308041.html
Copyright © 2011-2022 走看看