程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
您现在的位置: 程式師世界 >> 編程語言 >  >> 更多編程語言 >> Python

【python】二分查找算法

編輯:Python
nums = [-1, 1,2,3]
target = 3
class Solution:
  #定義全局變量,記錄右邊一半時的偏移量
global num_count
num_count = 0
def search(self, nums, target):
global num_count
if int(len(nums)) == 0:
return -1
elif target in nums:
mid = int(len(nums) / 2)
if nums[mid] == target:
  //最後返回時,需要加上右邊的偏移量
return mid+num_count
elif nums[mid] > target:
new_nums = nums[0:mid]
return self.search(new_nums, target)
elif nums[mid] < target:
  //左邊不需要加,右邊需要加上偏移量
num_count += mid
new_nums = nums[mid:int(len(nums))]
return self.search(new_nums, target)
else:
return -1
else:
return -1
aa = Solution()
bb = aa.search(nums, target)
print(bb)

  1. 上一篇文章:
  2. 下一篇文章:
Copyright © 程式師世界 All Rights Reserved