首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用heap-sort时输出错误(用python编写)

使用heap-sort时输出错误(用python编写)
EN

Stack Overflow用户
提问于 2012-10-16 02:53:43
回答 1查看 330关注 0票数 0

我已经写了下面的堆排序代码,我有时会得到错误的输出(未排序),并且我似乎找不到why...any帮助将非常感谢!

代码语言:javascript
复制
def heap_sort(self, a):

    heapsize = self.build_max_heap(a)

    n = len(a)-1
    i = len(a)-1

    for i in range(i, 0, -1):
        temp = a[0]
        a[0] = a[i]
        a[i] = temp
        heapsize = heapsize - 1
        self.max_heapify(heapsize, a, 0)       #rebuild max heap at with new root

    return a

def max_heapify(self, heapsize, a, i):

    left = (2*(i+1))-1      #left child of i
    right = 2*(i+1)             #right child of i
    largest = i

    if left < heapsize and a[left] > a[i]:
        largest = left

    if right < heapsize and a[right] > a[largest]:
        largest = right

    if largest != i:
        temp = a[largest]
        a[largest] = a[i]
        a[i] = temp
        self.max_heapify(heapsize, a, largest)

def build_max_heap(self, a):

    heapsize = len(a)
    i = int(heapsize/2)-1

    for i in range(i, 0):
        self.max_heapify(heapsize, a, i)

    return heapsize

我的测试:

代码语言:javascript
复制
#--Test for 0 in array--#
def zero_array(self):
    a = [12,0,232]
    print self.sort.heap_sort(a)
    return

#--Test for duplicate in array--#
def duplicate_array(self):
    a = [12, 12, 7]
    print self.sort.heap_sort(a)
    return

#--Test for all same values in array--#
def allsame_array(self):
    a = [1,1,1]
    print self.sort.heap_sort(a)
    return

#--Test for negative values in array--#
def negative_array(self):
    a = [-23, -2, 123]
    print self.sort.heap_sort(a)
    return

输出(应该全部排序):

代码语言:javascript
复制
    [0, 232, 12]
    [7, 12, 12]
    [1, 1, 1]
    [-2, 123, -23]
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-16 02:59:19

这可能是因为你的第二个range()是向前递增的而不是向后递增的。

代码语言:javascript
复制
for i in range(i, 0):

应该是:

代码语言:javascript
复制
for i in range(i, 0, -1):

您还需要记住,range()将在第二个参数之前停止,因此range(5, 0, -1)将返回[5, 4, 3, 2, 1]

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12902134

复制
相关文章

相似问题

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