Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/xcode/7.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在python for Kosaraju';中,如何解决这个堆栈溢出问题;s算法?_Python_Stack Overflow_Kosaraju Algorithm - Fatal编程技术网

在python for Kosaraju';中,如何解决这个堆栈溢出问题;s算法?

在python for Kosaraju';中,如何解决这个堆栈溢出问题;s算法?,python,stack-overflow,kosaraju-algorithm,Python,Stack Overflow,Kosaraju Algorithm,我是一名新的程序员,正在学习斯坦福大学关于edX的算法课程 编程任务之一是使用Kosaraju算法在一个有1000000个顶点的图上查找强连通的组件。我的实现是从教科书的伪代码到Python的最基本的翻译,它在较小的图形上运行良好,因此我认为它是正确的 Python的默认递归限制是1000,它达到了这个限制 我已经尝试了sys.setrecursionlimit(1000000),但这没有帮助,相反,我得到了“processfinishedwithexit code-1073741571”,这是

我是一名新的程序员,正在学习斯坦福大学关于edX的算法课程

编程任务之一是使用Kosaraju算法在一个有1000000个顶点的图上查找强连通的组件。我的实现是从教科书的伪代码到Python的最基本的翻译,它在较小的图形上运行良好,因此我认为它是正确的

Python的默认递归限制是1000,它达到了这个限制

我已经尝试了
sys.setrecursionlimit(1000000)
,但这没有帮助,相反,我得到了“processfinishedwithexit code-1073741571”,这是一个堆栈溢出

我发现这两个页面用于增加堆栈大小限制,但不确定如何使用它们中的任何一个:

另一个相关信息是Python没有优化尾部递归,但我不确定这是否适用于我的代码,因为它目前是这样的

G = {}
for i in range(1, 875715):
    G[i] = [0]
for l in open('SCC.txt'):
    items = list(map(int, l.split()))
    G[items[0]].append(items[1])

Grev = {}
for i in range(1, 875715):
    Grev[i] = [0]
for l in open('SCC.txt'):
    items = list(map(int, l.split()))
    Grev[items[1]].append(items[0])

def TopoSort(G):
    for v in G:
        if G[v][0] == 0:
            DFStopo(G, v)

def DFStopo(G, s):
    G[s][0] = 1
    global orderedVertexList
    for v in G[s][1:]:
        if G[v][0] == 0:
            DFStopo(G, v)
    orderedVertexList.insert(0, s)

def Kosaraju(G, Grev):
    TopoSort(Grev)
    global numSCC
    for v in orderedVertexList:
        if G[v][0] == 0:
            numSCC = numSCC + 1
            DFSSCC(G, v)

def DFSSCC(G, s):
    G[s][0] = 1
    global SCC
    SCC.append(numSCC)
    for v in G[s][1:]:
        if G[v][0] == 0:
            DFSSCC(G, v)

numSCC = 0
orderedVertexList = []
SCC = []

Kosaraju(copy.deepcopy(G), copy.deepcopy(Grev))

由于您的代码可以正常工作,但您需要帮助对其进行优化,因此您也可以在堆栈站点上询问构建自己的编程堆栈而不是依赖递归堆栈是非常常见的。我怀疑使用
int
对象的嵌套列表使用的内存比您实际需要的要多得多。考虑使用<代码> NoMPy < /Cord>数组。+ 1 WRT @ MZ的注释。消除递归而使用外部循环,并使用自己的堆栈跟踪算法的状态,这就是我解决问题的方法@G.Anderson:我通常在将用户推荐到不同的论坛时链接到