首頁  >  文章  >  後端開發  >  python二分法查找

python二分法查找

高洛峰
高洛峰原創
2016-12-19 16:32:332053瀏覽

下面是一段用Python實現的二分法查找程式碼

#encoding=utf-8  
  
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)

運行測試結果:

shao@ubuntu:~/tmp$ python test_search2.py 123456789 4  
3


更多python二分法查找相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn