Python实现二分查找算法实例


Posted in Python onMay 26, 2015

本文实例讲述了Python实现二分查找算法的方法。分享给大家供大家参考。具体实现方法如下:

#!/usr/bin/env python
import sys 
def search2(a,m):
  low = 0 
  high = len(a) - 1 
  while(low <= high):
    mid = (low + high)/2
    midval = a[mid]
    if midval < m:
      low = mid + 1 
    elif midval > m:
      high = mid - 1 
    else:
      print mid 
      return mid 
  print -1
  return -1
if __name__ == "__main__":
  a = [int(i) for i in list(sys.argv[1])]
  m = int(sys.argv[2])
  search2(a,m)

运行:

administrator@ubuntu:~/Python$ python test_search2.py 123456789 4
3

注:

1.'__':由于python的类成员都是公有、公开的被存取public,缺少像正统面向对象语言的私有private属性。

于是就用__来将就一下,模拟私有属性。这些__属性往往是内部使用,通常情况下不用改写。也不用读取。

加上2个下划线的目的,一是不和普通公有属性重名冲突,二是不让对象的使用者(非开发者)随意使用。

2.__name__ == "__main__"表示程序脚本是直接被执行的.
如果不等于表示脚本是被其他程序用import引入的.则其__name__属性被设为模块名

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

Python 相关文章推荐
Python切片工具pillow用法示例
Mar 30 Python
基于Django URL传参 FORM表单传数据 get post的用法实例
May 28 Python
Python中循环后使用list.append()数据被覆盖问题的解决
Jul 01 Python
Python实现基于PIL和tesseract的验证码识别功能示例
Jul 11 Python
如何使用Python 打印各种三角形
Jun 28 Python
Python完全识别验证码自动登录实例详解
Nov 24 Python
利用PyCharm操作Github(仓库新建、更新,代码回滚)
Dec 18 Python
tensorflow使用CNN分析mnist手写体数字数据集
Jun 17 Python
Python接口测试环境搭建过程详解
Jun 29 Python
python入门:argparse浅析 nargs='+'作用
Jul 12 Python
python boto和boto3操作bucket的示例
Oct 30 Python
手把手教你配置JupyterLab 环境的实现
Feb 02 Python
Django发送html邮件的方法
May 26 #Python
Python使用xlrd模块操作Excel数据导入的方法
May 26 #Python
django实现分页的方法
May 26 #Python
Django imgareaselect手动剪切头像实现方法
May 26 #Python
Django实现图片文字同时提交的方法
May 26 #Python
Python实现的简单算术游戏实例
May 26 #Python
Django中使用group_by的方法
May 26 #Python
You might like
探讨:如何编写PHP扩展
2013/06/13 PHP
PHP操作Redis常用技巧总结
2018/04/24 PHP
PHP使用标准库spl实现的观察者模式示例
2018/08/04 PHP
thinkphp5实现微信扫码支付
2019/12/23 PHP
php多进程中的阻塞与非阻塞操作实例分析
2020/03/04 PHP
js获取单元格自定义属性值的代码(IE/Firefox)
2010/04/05 Javascript
jQuery使用hide方法隐藏指定元素class样式用法实例
2015/03/30 Javascript
javascript判断变量是否有值的方法
2015/04/20 Javascript
浅谈javascript中return语句
2015/07/15 Javascript
原生JS和jQuery操作DOM对比总结
2017/01/19 Javascript
JavaScript数据结构之数组的表示方法示例
2017/04/12 Javascript
Bootstrap Table从零开始
2017/06/30 Javascript
Angular.js ng-file-upload结合springMVC的使用教程
2017/07/10 Javascript
VueJs使用Amaze ui调整列表和内容页面
2017/11/30 Javascript
react redux入门示例
2018/04/19 Javascript
让你5分钟掌握9个JavaScript小技巧
2018/06/09 Javascript
vuex 解决报错this.$store.commit is not a function的方法
2018/12/17 Javascript
javascrpt密码强度校验函数详解
2020/03/18 Javascript
基于vue hash模式微信分享#号的解决
2020/09/07 Javascript
一篇文章看懂JavaScript中的回调
2021/01/05 Javascript
[06:04]DOTA2英雄梦之声Vol19卓尔游侠
2014/06/20 DOTA
[01:17:12]职来职往完美电竞专场
2014/09/18 DOTA
Python插件virtualenv搭建虚拟环境
2017/11/20 Python
python基础教程项目五之虚拟茶话会
2018/04/02 Python
python3使用QQ邮箱发送邮件
2020/05/20 Python
Python3基本输入与输出操作实例分析
2020/02/14 Python
python脚本实现mp4中的音频提取并保存在原目录
2020/02/27 Python
Python logging日志模块 配置文件方式
2020/07/12 Python
细说CSS3中的选择符
2008/10/17 HTML / CSS
美国便宜的横幅和标志印刷在线:Best of Signs
2019/05/29 全球购物
西班牙高科技产品购物网站:MejorDeseo
2019/09/08 全球购物
机电专业大学生求职信
2013/10/04 职场文书
校园文明标语
2014/06/13 职场文书
农村门前三包责任书
2014/07/25 职场文书
解读MySQL的客户端和服务端协议
2021/05/10 MySQL
判断Python中的Nonetype类型
2021/05/25 Python