如何处理递归python排序函数中的作用域

2024-09-30 01:19:40 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在用Python实现Stooge排序,我不明白为什么我对数组排序所做的更改不起作用。换言之,当我递归地向下钻取时,单元似乎正在交换,但是在函数返回之后,数组的顺序没有改变。这是一个范围问题,还是其他一些我还不明白的pythonism?还是我的算法不正确

import math

def StoogeSort(A):

    n = len(A)

    if (n == 2 and A[0] > A[1]):

        tmp = A[0]
        A[0] = A[1]
        A[1] = tmp 

    elif n > 2:

        m = int(math.ceil((2 * n) / 3)) 
        StoogeSort(A[0:m]) 
        StoogeSort(A[m-n:n]) 
        StoogeSort(A[0:m]) 

    return A


A = [4,2,1]
StoogeSort(A)
print "End:",A
A = [44,12,8,33,100]
StoogeSort(A)
print "End:",A


Tags: 函数import算法排序顺序defmath数组
2条回答

1.-您正在向递归发送原始数组的副本,而不仅仅是原始数组的一部分。 2.-虽然您将发送原始数组的一部分,pseudocode Stooge Sort algorithm不处理数组的一部分,只处理索引

def StoogeSort(L, i, j):
    if L[i] > L[j]: #<  always switching elements (not just for n=2)
        L[j],L[i]=L[i],L[j]  
    if (j - i + 1) > 2:
        t = int((j - i + 1) / 3)
        StoogeSort(L, i, j-t)  #<  here, sending indexes.
        StoogeSort(L, i+t,j)
        StoogeSort(L, i, j-t)
    return L

>>> L = [7,8,9,5,6,4,2,1]
>>> StoogeSort(L, 0, len(L)-1)
[1, 2, 4, 5, 6, 7, 8, 9]

问题在于您的切片-A[0:m]等。这些切片不会在原始列表中创建视图,而是创建新的列表

可以使用at the bottom of this answer所述的numpy数组,或者使用递归调用的返回值来构造要返回的新列表

相关问题 更多 >

    热门问题