Python二分查找详解


Posted in Python onSeptember 13, 2015

先来看个实例

#!/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采用二分查找找出数字的下标

要考虑有重复数字的情况

class Solution(object):
  def searchRange(self, nums, target):
    """
    :type nums: List[int]
    :type target: int
    :rtype: List[int]
    """
    def binary_search(start,end,value):
      while end>=start:
        mid = (start+end)//2
        print(mid)
        if nums[mid]>target:
          end = mid-1
        elif nums[mid]<target:
          start = mid+1
        else: 
          if value==-1:
            if mid-1>=start and nums[mid+value] == target:
              end = mid+value
            else:
              return mid
          else:
            if mid+1<=end and nums[mid+value] == target:
              start = mid+value
            else:
              return mid
 
      return -1
    a=binary_search(0,len(nums)-1,-1)
    b=binary_search(0,len(nums)-1,1)
    return [a,b]
a = Solution()
l = [2,2]
print(a.searchRange(l,2))

二分算法的定义不在多说了,百度一下就知道(支持国产大笑)

import sys 
source = [1,2,3,4,5,6,7,8,9,10] #must be in order 
des = int(sys.argv[1]) 
low = 0 
high = len(source) - 1 
targetIndex = -1 
print "des=",des 
while low <= high: 
  middle = (low + high)/2 
  if des == source[middle]: 
    targetIndex = middle 
    break 
  elif des < source[middle]: 
    high = middle -1 
    print "middle element[index=",middle,",value=",source[middle],"] is bigger than des, continue search from[",low,"to",high,"]" 
  else: 
    low = middle + 1 
    print "middle element[index=",middle,",value=",source[middle],"] is smaller than des, continue search from[",low,"to",high,"]" 
print "search complete, target element's index in source list is ",targetIndex

最后在分享一个

'fileName--BinarySearch.py' 
 
src = [] 
 
def BinarySearch(low, high, target, *src): 
  '二分查找' 
  while low <= high: 
    mid = (low + high) // 2 
    midVal = src[mid] 
    if target < midVal: 
      high = mid - 1 
    elif target > midVal: 
      low = mid + 1 
    else: 
      return mid 
    BinarySearch(low, high, target, *src) 
 
print('Please input 10 number:') 
for number in range(10): 
  src.append(int(input('Num %d:' % number))) 
 
sortList = tuple(src) 
 
key = int(input('Please input key:')) 
location = BinarySearch(0, len(src) - 1, key, *sortList) 
 
if location != None: 
  print('Find target at %d' % (location + 1)) 
else: 
  print('No target!')
Python 相关文章推荐
Python中不同进制的语法及转换方法分析
Jul 27 Python
Python中struct模块对字节流/二进制流的操作教程
Jan 21 Python
Python实现的爬虫功能代码
Jun 24 Python
Python3实现发送QQ邮件功能(附件)
Dec 23 Python
Python 判断 有向图 是否有环的实例讲解
Feb 01 Python
python itchat给指定联系人发消息的方法
Jun 11 Python
Django基础知识 URL路由系统详解
Jul 18 Python
18个Python脚本可加速你的编码速度(提示和技巧)
Oct 17 Python
使用python3批量下载rbsp数据的示例代码
Dec 20 Python
python argparse传入布尔参数false不生效的解决
Apr 20 Python
pyspark给dataframe增加新的一列的实现示例
Apr 24 Python
PYTHON基于Pyecharts绘制常见的直角坐标系图表
Apr 28 Python
基python实现多线程网页爬虫
Sep 06 #Python
python杀死一个线程的方法
Sep 06 #Python
在Python的Flask框架中验证注册用户的Email的方法
Sep 02 #Python
Python实现身份证号码解析
Sep 01 #Python
实例Python处理XML文件的方法
Aug 31 #Python
通过实例浅析Python对比C语言的编程思想差异
Aug 30 #Python
使用Python脚本将文字转换为图片的实例分享
Aug 29 #Python
You might like
PHP 只允许指定IP访问(允许*号通配符过滤IP)
2014/07/08 PHP
分享一则PHP定义函数代码
2015/02/26 PHP
WordPress中用于检索模版的相关PHP函数使用解析
2015/12/15 PHP
yii2多图上传组件的使用教程
2018/05/10 PHP
javascript放大镜效果的简单实现
2013/12/09 Javascript
代码获取历史上的今天发生的事
2014/04/11 Javascript
JQuery给元素绑定click事件多次执行的解决方法
2014/05/29 Javascript
Bootstrap Validator 表单验证
2016/07/25 Javascript
关于javascript的一些知识以及循环详解
2016/09/12 Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
2018/06/14 Javascript
如何制作一个Node命令行图像识别工具
2018/12/12 Javascript
js实现文字头像的生成代码
2020/03/07 Javascript
Python getopt模块处理命令行选项实例
2014/05/13 Python
操作Windows注册表的简单的Python程序制作教程
2015/04/07 Python
举例详解Python中yield生成器的用法
2015/08/05 Python
python制作一个桌面便签软件
2015/08/09 Python
python高手之路python处理excel文件(方法汇总)
2016/01/07 Python
老生常谈进程线程协程那些事儿
2017/07/24 Python
Python实现的快速排序算法详解
2017/08/01 Python
详解分布式任务队列Celery使用说明
2018/11/29 Python
Python安装selenium包详细过程
2019/07/23 Python
应用OpenCV和Python进行SIFT算法的实现详解
2019/08/21 Python
用Python自动清理电脑内重复文件,只要10行代码(自动脚本)
2021/01/09 Python
HTML5实现多张图片上传功能
2016/03/11 HTML / CSS
Html5 APP中监听返回事件处理的方法示例
2018/03/15 HTML / CSS
Nike挪威官网:Nike.com (NO)
2018/11/26 全球购物
sort命令的作用和用法
2013/08/25 面试题
酒店个人培训自我鉴定
2013/12/11 职场文书
成绩单家长评语大全
2014/04/16 职场文书
竞选班干部演讲稿100字
2014/08/20 职场文书
党的群众路线教育实践活动组织生活会发言材料
2014/10/17 职场文书
初中生散播谣言检讨书
2014/11/17 职场文书
大学生读书笔记大全
2015/07/01 职场文书
银行培训心得体会范文
2016/01/09 职场文书
创业计划书之酒厂
2019/10/14 职场文书
Python爬虫之爬取最新更新的小说网站
2021/05/06 Python