簡體   English   中英

Python-就地快速排序程序

[英]Python- Quicksort program in-place

我這里有一個快速排序程序,但結果似乎有問題。 我認為在引用某些值時,在下面突出顯示的區域中一定存在一些問題。 有什么建議?

#where l represents low, h represents high
def quick(arr,l,h):
    #is this the correct array for quicksorting?
    if len(x[l:h]) > 1:
        #r is pivot POSITION
        r = h
        #R is pivot ELEMENT
        R = arr[r]
        i = l-1
        for a in range(l,r+1):  
            if arr[a] <= arr[r]:
                i+=1
                arr[i], arr[a] = arr[a], arr[i]
        #should I take these values? Note that I have repeated elements below, which is what I want to deal with
        quick(arr,l,arr.index(R)-1)
        quick(arr,arr.index(R)+arr.count(R),h)

x = [6,4,2,1,7,8,5,3]

quick(x,0,len(x)-1)

print(x)
 #should I take these values? Note that I have repeated elements below, which is what I want to deal with quick(arr,l,arr.index(R)-1) quick(arr,arr.index(R)+arr.count(R),h)

您似乎假設等於樞軸元素的值已經是連續的。 對於您當前的實現,這種假設可能是錯誤的。 例如通過在遞歸之前輸出完整列表來測試它。

要使假設成立,請將其划分為三個而不是兩個組,如Wikipedia 中所述

請檢查這個。 我想你找到了答案。

def partition(array, begin, end):
    pivot = begin
    for i in xrange(begin+1, end+1):
        if array[i] <= array[begin]:
            pivot += 1
            array[i], array[pivot] = array[pivot], array[i]
    array[pivot], array[begin] = array[begin], array[pivot]
    return pivot


def quicksort(array, begin=0, end=None):
    if end is None:
        end = len(array) - 1
    if begin >= end:
        return
    pivot = partition(array, begin, end)
    quicksort(array, begin, pivot-1)
    quicksort(array, pivot+1, end)

array = [6,4,2,1,7,8,5,3]
quicksort(array)
print (array)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM