mid=(low + high)这里为什么不除以2呢
想问一下,mid=(low + high)这里为什么不除以2呢,我 输入 mid=(low + high)/2再运行代码就是错的本帖最后由 isdkz 于 2023-6-7 14:33 编辑
在这个二分查找的算法中,你需要计算中间索引,这个索引应该是low和high索引的平均值,所以应该除以2。但是在Python中,除法运算符"/"返回的是一个浮点数,这样可能会导致mid不再是整数,而在索引列表时,我们需要一个整数索引。所以,你应该使用"//"运算符,它会进行整数除法(也称为地板除),这样可以得到一个整数结果。
所以,你应该将mid=(low + high)修改为mid=(low + high)//2 。
修正后的代码如下:
def binary_search(list, item):
low = 0
high=len(list)-1
while low<=high:
mid=(low + high)//2
guess=list
if guess==item:
return mid
if guess>item:
high=mid-1
else:
low=mid+1
return None
my_list=
print(binary_search(my_list, 7))
现在这个函数应该可以正常工作了。如果输入的item在列表中,函数将返回item的索引;如果item不在列表中,函数将返回None。 那为啥不用地板除//, 光写成这样mid=(low + high)也能行呢 isdkz 发表于 2023-6-7 14:32
在这个二分查找的算法中,你需要计算中间索引,这个索引应该是low和high索引的平均值,所以应该除以2。但是 ...
那为啥不用地板除//, 光写成这样mid=(low + high)也能行呢 pionrrt 发表于 2023-6-7 14:44
那为啥不用地板除//, 光写成这样mid=(low + high)也能行呢
实际上,这样写mid=(low + high)是错误的。这不是计算low和high的平均值(也就是中间值),而只是简单地将low和high相加。在二分查找算法中,我们应该找到low和high的平均值来得到中间索引,所以我们应该使用mid=(low + high)//2 。
如果只是mid=(low + high) ,在某些情况下可能会导致错误或者查找效率低下,因为这并没有真正地将查找范围减半。
所以,正确的写法应该是mid=(low + high)//2 。如果你在某些情况下看到mid=(low + high)也能行,可能只是因为这种情况下恰好得到了正确的结果,但这并不代表这种写法是正确的。 isdkz 发表于 2023-6-7 15:09
实际上,这样写mid=(low + high)是错误的。这不是计算low和high的平均值(也就是中间值),而只是简 ...
嗯 好的,谢谢!
页:
[1]