>백엔드 개발 >파이썬 튜토리얼 >Python 힙 정렬 알고리즘 예제 코드

Python 힙 정렬 알고리즘 예제 코드

伊谢尔伦
伊谢尔伦원래의
2017-06-28 13:47:251504검색

python은 힙 정렬 알고리즘 코드를 구현했습니다. 필요한 친구들은 참고하면 됩니다.

코드는 다음과 같습니다.

#!/usr/bin/python 
import sys 
def left_child(node): 
return
 node * 2 + 1 
def 
right
_child(node): 
return node * 2 + 2 
def parent(node): 
if (node % 2): 
return (i - 1) / 2 
else: 
return (i - 2) / 2 
def max_heapify(
array
, i, heap_size): 
l = left_child(i) 
r = right_child(i) 
largest = i 
if l < heap_size and array[l] > array[i]: 
largest = l 
if r < heap_size and array[r] > array[largest]: 
largest = r 
if largest != i: 
array[i], array[largest] = array[largest], array[i] 
max_heapify(array, largest, heap_size) 
def build_max_heap(array): 
for i in 
range
(len(array) / 2, -1, -1): 
max_heapify(array, i, len(array)) 
def heap_sort(array): 
build_max_heap(array) 
for i in range(len(array) - 1, 0, -1): 
array[0], array[i] = array[i], array[0] 
max_heapify(array, 0, i) 
if name == "
main
": 
array = [0, 2, 6, 98, 34, -5, 23, 11, 89, 100, 7] 
heap_sort(array) 
for a in array: 
sys.stdout.write("%d " % a)


위 내용은 Python 힙 정렬 알고리즘 예제 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.