首頁 >後端開發 >Python教學 >python實作二分查找與快速排序實例詳解

python實作二分查找與快速排序實例詳解

黄舟
黄舟原創
2017-10-14 10:23:372440瀏覽

本文透過實例程式碼給大家詳細介紹了python 二分查找和快速排序,的相關知識,需要的朋友可以參考下

思想簡單,細節頗多;本以為很簡單的兩個小程序,寫起來發現bug頻出,留此紀念。


#usr/bin/env python
def binary_search(lst,t):
  low=0
  height=len(lst)-1
  quicksort(lst,0,height)
  print lst
  while low<=height: 
    mid = (low+height)/2
    if lst[mid] == t:
      return lst[mid]
    elif lst[mid]>t:
      height=mid-1
    else:
      low=mid+1
  return -1
def quicksort( lst, left , right):
  low=left
  high=right
  key=lst[left]
  if left>=right:
    return 0
  while low<high:
    while low<high and key<lst[high]:
      high=high-1
    lst[low]=lst[high]
    while low<high and key>lst[low]:
      print lst[low]
      low=low+1
    lst[high]=lst[low]
    lst[low]=key
  quicksort( lst , left ,low-1)
  quicksort( lst , low+1 , right)
if __name__==&#39;__main__&#39;:
  print binary_search([4,8,1,5,10,2,12,3,6,9],4)

#總結

#

以上是python實作二分查找與快速排序實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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