合并排序“比较超过最大递归深度” [重复]

Posted

技术标签:

【中文标题】合并排序“比较超过最大递归深度” [重复]【英文标题】:Merge sort "maximum recursion depth exceeded in comparison " [duplicate] 【发布时间】:2019-01-21 15:18:09 【问题描述】:

我想在 Python 3 中编写归并排序代码。

这是我的代码:

import math

def Merge(array,start,mid,end):
    n1 = mid - start +1
    n2 = end - mid
    i = 0
    j = 0
    left = [None] * n1
    right = [None] * n2
    inv = 0
    for i in range(0,n1):
        left[i] = array[start + i - 1]
    for j in range(0,n2):
        right[j] = array[mid + j]

    left.append(math.inf)
    right.append(math.inf)
    new_list = []
    for k in range(0,end):
        if left[i] <= right[j]:
            array[k] = left[i]
            i+=1
        elif left[i] > right[j]:
            array[k] = right[j]
            j+=1

def MergeSort(array,start,end):
    if len(array) <= 1:
        return array
    mid = math.ceil((start + end)/2)
    MergeSort(array,start,mid)
    MergeSort(array,mid+start,end)
    Merge(array,start,mid,end)


stuff = [1, -5, 17, 32, 6] 
MergeSort(stuff, 0, len(stuff))
print(stuff)

我测试了第一个功能(合并),它可以正常工作。但是我有递归的问题。我无法弄清楚问题出在哪里。错误是“比较中超出了最大递归深度”。

【问题讨论】:

Minimal, complete, verifiable example 适用于此。在您发布 MCVE 代码并准确描述问题之前,我们无法有效地帮助您。我们应该能够将您发布的代码粘贴到文本文件中并重现您描述的问题。您发布的代码定义了两个函数并在没有任何调用的情况下退出。 在您的 MergeSort 函数中插入这一行(作为第一行),然后自己看看 print("Start %i End %i" % (start,end)) 发生了什么。这与递归限制无关 似乎for k in range(0,end): 应该是for k in range(start,end): 【参考方案1】:

MergeSort 没有功能退出。列表的长度永远不会改变,因为您在每次调用时都会传递整个列表。如果您从列表中的 5 个元素开始,那么len(array) 始终为 5。因此,您会找到左侧的基本项(一个元素)并继续永远敲击该元素。

尝试检查边界,例如

if end - start <= 1:

这至少会让你解决下一个执行问题。


查看这个可爱的debug 博客寻求帮助。如果不出意外,学习放入有用的print 语句来跟踪数据和控制流。

【讨论】:

为关于调试的博文点赞。 该博客是 Stack Overflow 上的标准“最爱”。我已经将它添加为书签至少一年了。

以上是关于合并排序“比较超过最大递归深度” [重复]的主要内容,如果未能解决你的问题,请参考以下文章

比较超过最大递归深度?

比较超过最大递归深度

合并排序——二路合并排序

使用合并排序对(名称)进行排序

Binary Search RecursionError:比较超过最大递归深度

在线性时间内将小的排序列表合并为更大的排序列表的算法,没有重复项