3
我已經編寫了以下代碼來計算數組數組中的倒數的數目。它給出了我測試它的輸入的正確結果,但仍然失敗測試用例,我無法訪問測試用例,我無法弄清楚它會失敗的情況,我真的可以在這裏使用一些幫助。以下哪種情況下使用合併排序倒計數的算法將失敗
def count_inversion(array):
"""
counts number of inversions in array using divide and conquer
an inversion is a pair (x,y) such that x > y, example in array
[3,1,2] there are two inversions (3,1), (3,2)
"""
length = len(array)
if length == 1 or length == 0:
return array,0
elif length == 2:
if array[0] > array[1]:
array.sort()
return array,1
else:
return array,0
else:
left_array,left_count = count_inversion(array[:length/2])
right_array,right_count = count_inversion(array[length/2:])
across_arr,across_count = count_split(left_array,right_array)
return across_arr,left_count + right_count + across_count
def count_split(left,right):
"""
counts the number of inversions across split pair
left and right, by piggy backing on merge routine
of merge sort
"""
l = 0
r = 0
merge = []
count = 0
inversions = 0
last_r = 0
try:
while True:
if left[l] > right[r]:
merge.append(right[r])
if r == 0 or r == last_r:
inversions = 0
inversions += 1
r = r + 1
else:
merge.append(left[l])
count = count + inversions
l = l + 1
last_r = r
except IndexError:
if r == len(right):
while l < len(left):
count += inversions
merge.append(left[l])
l = l + 1
else:
while r < len(right):
merge.append(right[r])
r = r + 1
return merge,count
if __name__ == '__main__':
f = open('inversions.txt')
arr = []
for line in f:
arr.append(int(line))
# arr is a list of integers which are not sorted in any sense
# we are required to count number of inversions in arr
print count_inversion(arr)[1]
它不在異常塊中,錯誤實際上是我計算反轉次數的方式,但是您的示例幫助我獲得了該錯誤。非常感謝:) – 2012-03-29 02:22:16
明顯的錯誤N1:在異常塊中首先用count + = r替換count + = inversion。 – kilotaras 2012-03-29 15:09:58
是的,這就是我所做的,謝謝 – 2012-04-01 10:15:50