2021-04-18python 二叉搜索

二叉搜索:
第一步,先取中間位置值進行比較;
第二步,在大于或者小于的一部分進行比較;
重復第一、二步。


def binarySearch(target,sortedLyst):
    left = 0
    right = len(sortedLyst) -1
    while  left<= right:
        print(left,right)
        midpoint = (left+right)//2
        print(midpoint,target)
        if target == sortedLyst[midpoint]:
            return midpoint
        elif target < sortedLyst[midpoint]:
            right = midpoint -1
        else:
            left = midpoint +1
    return -1

lys = [20,44,48,55,62,66,74,88,93,99]
binarySearch(90,lys)
binarySearch(44,lys)

結果:

0 9
4 90
5 9
7 90
8 9
8 90
0 9
4 44
0 3
1 44

python 內建類對象比較。eq ==; it 小于; gt 大于。

class SavingAccount(object):

    def __init__(self,name,pin,balance=0.0,num=0.0):
        self._name = name
        self._pin = pin
        self._balance = balance
        self._num = num

    def __eq__(self, other):
        return self._num==other._num

    def __lt__(self, other):
        print(other._name,other._balance,other._num)
        print(self._name,self._balance,self._num)
        return self._num < other._num

    def __gt__(self, other):
        print(other._name, other._balance, other._num)
        print(self._name, self._balance, self._num)
        return self._num > other._num

    def __str__(self):
        return str(self._name + self._pin+ str(self._balance)+str(self._num))


?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容