Merge pull request #1792 from PeterLijunfeng/master

0704Python版本严格参照C++写法及次序,并追加注释
This commit is contained in:
程序员Carl
2022-12-20 11:01:06 +08:00
committed by GitHub

View File

@ -204,18 +204,18 @@ class Solution {
```python ```python
class Solution: class Solution:
def search(self, nums: List[int], target: int) -> int: def search(self, nums: List[int], target: int) -> int:
left, right = 0, len(nums) - 1 left, right = 0, len(nums) - 1 # 定义target在左闭右闭的区间里[left, right]
while left <= right:
middle = (left + right) // 2
if nums[middle] < target: while left <= right:
left = middle + 1 middle = left + (right - left) // 2
elif nums[middle] > target:
right = middle - 1 if nums[middle] > target:
right = middle - 1 # target在左区间所以[left, middle - 1]
elif nums[middle] < target:
left = middle + 1 # target在右区间所以[middle + 1, right]
else: else:
return middle return middle # 数组中找到目标值,直接返回下标
return -1 return -1 # 未找到目标值
``` ```
(版本二)左闭右开区间 (版本二)左闭右开区间
@ -223,18 +223,18 @@ class Solution:
```python ```python
class Solution: class Solution:
def search(self, nums: List[int], target: int) -> int: def search(self, nums: List[int], target: int) -> int:
left, right = 0, len(nums) left, right = 0, len(nums) # 定义target在左闭右开的区间里[left, right)
while left < right: while left < right: # 因为left == right的时候在[left, right)是无效的空间,所以使用 <
middle = (left + right) // 2 middle = left + (right - left) // 2
if nums[middle] < target: if nums[middle] > target:
left = middle + 1 right = middle # target 在左区间,在[left, middle)中
elif nums[middle] > target: elif nums[middle] < target:
right = middle left = middle + 1 # target 在右区间,在[middle + 1, right)中
else: else:
return middle return middle # 数组中找到目标值,直接返回下标
return -1 return -1 # 未找到目标值
``` ```
**Go** **Go**