gpt4 book ai didi

arrays - 计算反转?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:39:30 26 4
gpt4 key购买 nike

我有这段代码可以计算数组中的反转次数。它适用于小型阵列。

但对于大小超过 500 的数组,该值与正确值相差 20 -50

def merge(left,right):
result=[]
i,j,inv=0,0,0
while i<len(left) and j<len(right):
if left[i]<right[j]:
result.append(left[i])
i=i+1
else:
result.append(right[j])
j=j+1
inv=inv+len(left)-i
result+=left[i:]
result+=right[j:]
return result,inv


def mergesort(li):
if len(li)<2:
return li,0
middle=len(li)//2
left,invl=mergesort(li[:middle])
right,invr=mergesort(li[middle:])
result,invs= merge(left,right)
inv=invl+invr+invs
return result,inv




if __name__ == '__main__':
n=int(raw_input())
ans=[]
for i in range(n):
m=int(raw_input())
li=raw_input().split(' ')
print len(li)
result,inversions=mergesort(li)
ans.append(inversions)
for i in range(n):
print ans[i]

我错过了什么?

最佳答案

你不需要大数组来获得错误的反转计数:

>>> mergesort([1,1,1,1])
([1, 1, 1, 1], 6)

你的错误在于你将所有相等元素对都算作反转,

if left[i]<right[j]:
result.append(left[i])
i=i+1

应该是

if left[i] <= right[j]:
result.append(left[i])
i=i+1

这样相等的元素就不会被交换并算作反转。

您收到的短数组不包含重复项,但较大的数组包含重复项。

关于arrays - 计算反转?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11803406/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com