我在python中写了一个合并算法。它可以完美地工作,直到10000个数字,但是10000后它给了我细分故障11.可能是什么问题?关于它的任何想法
def merge_count(arr):
if len(arr) < 2:
return (arr, 0)
m = int(len(arr) / 2)
left, l_counter = merge_count(arr[:m])
right, r_counter = merge_count(arr[m:])
return merge(left, right, l_counter + r_counter)
def merge(left, right, counter):
if len(left) * len(right) == 0:
return (left + right, counter)
if left[len(left) - 1] > right[len(right) - 1]:
val = left.pop(len(left) - 1)
counter += len(right)
else:
val = right.pop(len(right) - 1)
arr, counter = merge(left, right, counter)
return (arr + [val], counter)
看起来您有堆栈溢出。merge
在列表大小合并的顺序上使用堆栈空间,这比Python可以处理的要多。通常,python会在您到达这一点之前阻止您使用RuntimeError
。您可能使用sys.setrecursionlimit
超过了安全限制。停止使用setrecursionlimit
,然后重写merge
不使用递归。