Here is my code.
@@inversions = 0
numbers = [very big array]
def merge_sort(array)
return array if array.size <= 1
left = array.slice(0, (array.size / 2).round)
right = array - left
merge(merge_sort(left), merge_sort(right))
end
def merge(left, right)
return right if left.empty? # crashes here with stack level too deep
return left if right.empty?
if left.first <= right.first
[left.first] + merge(left[1..-1], right)
else
@@inversions += left.size
[right.first] + merge(left, right[1..-1])
end
end
Can you please tell why it fails? (works on arrays less than ~ 15000 size)
Your recursive merge function is probably the reason. You are going one level deeper in the stack for each element in the array. A standard merge sort shouldn’t go deeper than lg(N). Try rewriting
mergeto be iterative instead of recursive.Something like