python编程300例之 005二分查找

 1 # binarysearch
 2 # 给定一个排序的整数数组(升序),和一个要查找的目标整数target
 3 # 查找到target第一次出现的的下标(从0开始)如果数组中没有就返回-1
 4 """
 5 输入数组[1,4,4,5,7,7,8,9,9,10]和目标整数1,输出其所在的位置为0,即第一次出现第0个位置.输入数组[1,2,3,3,4,5,10]和
 6 目标整数3,输出2,即第一次出现在第二个位置
 7 """
 8 
 9 
10 class Solution:
11     def binarySearch(self, nums, target):
12         left = 0
13         right = len(nums) - 1
14         while 1:
15             middle = (left + right) // 2
16             if left <= right:
17                 if nums[middle] > target:
18                     right = middle - 1
19                 elif nums[middle] < target:
20                     left = middle + 1
21                 else:
22                     return middle
23             else:
24                 return -1
25 
26 
27 c1 = Solution()
28 print(c1.binarySearch([1, 4, 4, 5, 7, 7, 8, 9, 9, 10], 6))

 

上一篇:Android : Found byte-order-mark in the middle of a file


下一篇:CCF认证 2019-3 小中大