首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >python中的快速排序- CLRS实现

python中的快速排序- CLRS实现
EN

Stack Overflow用户
提问于 2014-09-08 20:00:30
回答 2查看 1.3K关注 0票数 2

我正在尝试在python中实现快速排序。CLRS algo版本。

这是我写的。我认为,除了清单中的中间部分外,大多数情况下都很好。

有人能帮忙吗?

代码语言:javascript
复制
#! /usr/bin/python

#quick sort

def swap(array,i,j):
    temp = array[i]
    array[i] = array[j]
    array[j] = temp

def partition(array, start,end):
    x = array[end]
    i = start -1
    for j in xrange(start+1, end):
        if (array[j] <= x):
            i = i+1
            swap (array,i,j)
        swap(array,i+1,end)
    return i+1

def quicksort(array,p,r):
    if p<r:
        q = partition(array,p,r)
        quicksort(array,p,q-1)
        quicksort(array,q+1,r)

def main():
    unsortedArray = [2,8,7,1,3,5,6,4,9,0]
    quicksort(unsortedArray,0,len(unsortedArray)-1)
    print unsortedArray


if __name__ == '__main__':
    main()

输出应该是[0,1,2,3,4,5,6,7,8,9].Instead,它正在打印[2, 0, 3, 4, 1, 6, 5, 7, 9, 8]

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-09-08 20:11:13

根据我在https://users.cs.fiu.edu/~giri/teach/5407/F08/Lec7.pdf上找到的伪代码,您的partition实现是错误的,因为

代码语言:javascript
复制
swap(array,i+1,end)

是否应该在每次迭代中执行而不是,而是只在函数中执行一次。

我把它改写成这样:

代码语言:javascript
复制
def partition(array, start,end):
    x = array[end]
    i = start -1
    for j in xrange(start, end):
        if (array[j] <= x):
            i = i+1
            swap (array,i,j)
    swap(array,i+1, end)
    return i+1

而且效果很好。

票数 2
EN

Stack Overflow用户

发布于 2020-01-19 15:37:35

使分区()变得更简单和Pythonic。

  • 不需要交换()。
  • 使用枚举()访问列表中的元素
代码语言:javascript
复制
def partition(A, p, r):
    pivot = A[r]
    i = -1
    for j, n in enumerate(A):
        if A[j] <= pivot:
            i += 1
            A[i], A[j] = A[j], A[i]
    return i
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25732203

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档