现在,我已经编写了Python(2.7版)的二进制搜索。有时,它工作正常,但有时它会返回None,尽管搜索的值在数组中。我已经尝试了解决这个问题的每个简单方法:我已经检查了函数返回的变量是否被定义,是否执行了返回语句所在的工作流的分支。并且:变量是定义的,分支是执行的。
以下是代码:
def binarySearch( array, desiderata, iMin, iMax ):
# Returns the index of the first instance of what we search
print 'min'
print iMin
print 'max'
print iMax
# If our search array is empty
if ( iMin > iMax ):
return None
midP = (iMin + iMax)/2
curre = tapeNr( array[midP][TAPE_NUMBER] )
final = tapeNr( desiderata )
print 'curre'
print curre
print 'final'
print final
print 'midP'
print midP
if ( curre < final ):
# print midP
print "t: " + array[midP][TAPE_NUMBER] + ", d: " + desiderata
binarySearch( array, desiderata, midP + 1, iMax )
else:
if ( curre > final ):
# print midP
print "t: " + array[midP][TAPE_NUMBER] + ", d: " + desiderata
binarySearch( array, desiderata, iMin, midP - 1 )
else:
print 'hooray'
# Now, find the first occurence of the value I need
i = midP
while ( array[i][TAPE_NUMBER] == desiderata ):
i -= 1
print i
print (i + 1)
return (i + 1)
由于我的调试,有很多'print'语句。 最后一个,'print(i + 1)',实际打印(!)我需要的东西的索引值,但该函数仍然返回None。
您是否对问题的根源有所了解?
答案 0 :(得分:5)
您忽略递归调用的返回值:
binarySearch( array, desiderata, midP + 1, iMax )
和
binarySearch( array, desiderata, iMin, midP - 1 )
所以当curre < final
为True
时:
if ( curre < final ):
# print midP
print "t: " + array[midP][TAPE_NUMBER] + ", d: " + desiderata
binarySearch( array, desiderata, midP + 1, iMax )
你打电话给binarySearch()
,然后你的功能结束。如果没有显式返回,则表示您的函数返回值设置为None
。
将return
语句添加到这些行:
return binarySearch( array, desiderata, midP + 1, iMax )
# ...
return binarySearch( array, desiderata, iMin, midP - 1 )