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下载指定页面上图片的方法
May 12 Python
python实现日常记账本小程序
Mar 10 Python
python画图系列之个性化显示x轴区段文字的实例
Dec 13 Python
基于Python实现迪杰斯特拉和弗洛伊德算法
May 27 Python
几行Python代码爬取3000+上市公司的信息
Jan 24 Python
python实现计数排序与桶排序实例代码
Mar 28 Python
Python之NumPy(axis=0 与axis=1)区分详解
May 27 Python
cProfile Python性能分析工具使用详解
Jul 22 Python
Pandas 缺失数据处理的实现
Nov 04 Python
pytorch实现seq2seq时对loss进行mask的方式
Feb 18 Python
Python run()函数和start()函数的比较和差别介绍
May 03 Python
Python新手学习函数默认参数设置
Jun 03 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源码之 ext/mysql扩展部分
2009/07/17 PHP
详解php设置session(过期、失效、有效期)
2015/11/12 PHP
php连接oracle数据库的方法(测试成功)
2016/05/26 PHP
php通过会话控制实现身份验证实例
2016/10/18 PHP
php的常量和变量实例详解
2017/06/27 PHP
Jsonp post 跨域方案
2015/07/06 Javascript
js仿微博实现统计字符和本地存储功能
2015/12/22 Javascript
浅谈JavaScript的内置对象和浏览器对象
2016/06/03 Javascript
jQuery如何解决IE输入框不能输入的问题
2016/10/08 Javascript
详解如何将angular-ui的图片轮播组件封装成一个指令
2017/05/09 Javascript
解决html-jquery/js引用外部图片时遇到看不了或出现403的问题
2017/09/22 jQuery
JS生成随机打乱数组的方法示例
2017/12/23 Javascript
分享ES6的7个实用技巧
2018/01/18 Javascript
基于vue开发的在线付费课程应用过程
2018/01/25 Javascript
详解webpack4.x之搭建前端开发环境
2019/03/28 Javascript
Node.js 路由的实现方法
2019/06/05 Javascript
python 与GO中操作slice,list的方式实例代码
2017/03/20 Python
Python 使用with上下文实现计时功能
2018/03/09 Python
TensorFlow实现卷积神经网络CNN
2018/03/09 Python
使用PyQt4 设置TextEdit背景的方法
2019/06/14 Python
Flask教程之重定向与错误处理实例分析
2019/08/01 Python
python生成器推导式用法简单示例
2019/10/08 Python
简单了解python数组的基本操作
2019/11/26 Python
Python getsizeof()和getsize()区分详解
2020/11/20 Python
python中scipy.stats产生随机数实例讲解
2021/02/19 Python
Hotels.com爱尔兰:全球酒店预订
2017/02/24 全球购物
美国知名女性服饰品牌:New York & Company
2017/03/23 全球购物
Veronica Beard官网:在酷、经典和别致之间找到了平衡
2018/01/11 全球购物
俄罗斯Sportmarket体育在线商店:用于旅游和户外活动
2019/11/12 全球购物
销售总监工作职责
2013/11/21 职场文书
皮肤科医师岗位职责
2013/12/04 职场文书
服务承诺书格式
2014/05/21 职场文书
事业单位个人查摆问题及整改措施
2014/10/28 职场文书
高三毕业评语
2014/12/31 职场文书
2015年小学语文教学工作总结
2015/05/25 职场文书
JavaScript执行机制详细介绍
2021/12/06 Javascript