今天同事說到了一個python的排序模塊bisect濒蒋,覺得挺有趣的,跟大家分享分享。
先看看模塊的結(jié)構(gòu):
data:image/s3,"s3://crabby-images/db102/db102260140db2e370d5795df72c038bb40020bc" alt="image"
前面五個屬性大家感興趣可以打出來看看數(shù)值沪伙,這里就不介紹了瓮顽。
先說明的是,使用這個模塊的函數(shù)前先確保操作的列表是已排序的围橡。
data:image/s3,"s3://crabby-images/76473/76473ac33bd300085a910f7a872d7e162e77e338" alt="image"
先看看 insort 函數(shù):
data:image/s3,"s3://crabby-images/6207a/6207a5f3b6c9391cac5eb430d0f228219aafffd4" alt="image"
其插入的結(jié)果是不會影響原有的排序暖混。
再看看 bisect 函數(shù):
data:image/s3,"s3://crabby-images/20105/2010543a4bac6c21899c275e1915b18db3d43849" alt="image"
其目的在于查找該數(shù)值將會插入的位置并返回,而不會插入翁授。
接著看 bisect_left 和 bisect_right 函數(shù)拣播,該函數(shù)用入處理將會插入重復(fù)數(shù)值的情況,返回將會插入的位置:
data:image/s3,"s3://crabby-images/61b43/61b433168bb9a7e799dc7fb49f3d0c214f518345" alt="image"
其對應(yīng)的插入函數(shù)是 insort_left 和 insort_right :
data:image/s3,"s3://crabby-images/824be/824be128a7d19b0d1fa22cdf6659562eed3980f7" alt="image"
可見收擦,單純看其結(jié)果的話贮配,兩個函數(shù)的操作結(jié)果是一樣的,其實插入的位置不同而已塞赂。