欢迎来到山村网

Python二分法搜索算法实例分析

2019-03-02 12:33:00浏览:921 来源:山村网   
核心摘要:  这篇文章主要介绍了Python二分法搜索算法,实例分析了Python实现二分法的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考

  这篇文章主要介绍了Python二分法搜索算法,实例分析了Python实现二分法的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下

  今天看书时,书上提到二分法虽然道理简单,大家一听就明白但是真正能一次性写出别出错的实现还是比较难的,即使给了你充足的时间,比如1小时。如果你不是特别认真的话,可能还是会出一些这样那样的错误,所以就尝试了自己去实现一下,看能否一次通过,结果自然不言而喻,虽然用的时间不长,但是我失败了,呵呵。

  个人觉得失败的最主要原因是自己没有认真的先想好这个思路和可能出现的分支情况,而是直接凭主观臆想就去写代码了,完全正中书上所说的行为,所以也如书上所说,出错了。后经调试应该是得到了基本的正确算法,内容如下:

  ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 #!/usr/bin/env python #encoding: utf-8 def half_search(search_arr, search_str): lb = 0 ub = len(search_arr) - 1 for i in range(ub/2 + 1): if lb > ub: return -1 mid = (ub + lb)/2 if search_arr[mid] == search_str: return mid elif search_arr[mid] > search_str: ub = mid - 1 else: lb = mid + 1 if __name__=='__main__': arr = [10,20,30,40,50,60,70] print half_search(arr, 1) print half_search(arr, 11) print half_search(arr, 22) print half_search(arr, 33) print half_search(arr, 40) print half_search(arr, 55) print half_search(arr, 66) print half_search(arr, 70) print half_search(arr, 8)

  结果:

  ?

1 2 3 4 5 6 7 8 9 -1 -1 -1 -1 3 -1 -1 6 -1

  正整数代表在数组中的下标,3那就是第4个位置;-1代表不存在

  总结:

  实现简单的算法之前,如果已经有了一套最简易的实现【比如直接打印100条相似的内容】,不妨要想想是否还有更精巧的实现【可否用循环+参数化替代】;实现稍微复杂点的算法时,不妨先在纸上画出各种可能的验证情况,避免实现是缺胳膊短腿的;还有一点就是算法什么的还是要多练,不然稍微复杂的过一阵可能就会忘记细节了。我想这就叫术业有专攻吧!

  希望本文所述对大家的Python程序设计有所帮助。

(责任编辑:豆豆)
下一篇:

python比较2个xml内容的方法

上一篇:

python处理图片之PIL模块简单使用方法

  • 信息二维码

    手机看新闻

  • 分享到
打赏
免责声明
• 
本文仅代表作者个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,作者需自行承担相应责任。涉及到版权或其他问题,请及时联系我们 xfptx@outlook.com