HeapSort 堆排序 基于伪代码实现

 此文原创, http://www.cnblogs.com/baokang/p/4735431.html ,禁止转载

GIF 动态图 

 

 

伪代码

/* From Wikipedia, the free encyclopedia */

1.父子节点特征

iParent = floor((i-1) / 2);
iLeftChild = 2*i + 1;
iRightChild = 2*i + 2;

2.算法伪代码

/* 保持原汁原味就不翻译了 =。= */

procedure heapsort(a, count) is
    input: an unordered array a of length count
 
    (Build the heap in array a so that largest value is at the root)
    heapify(a, count)

    (The following loop maintains the invariants that a[0:end] is a heap and every element
     beyond end is greater than everything before it (so a[end:count] is in sorted order))
    end ← count - 1
    while end > 0 do
        (a[0] is the root and largest value. The swap moves it in front of the sorted elements.)
        swap(a[end], a[0])
        (the heap size is reduced by one)
        end ← end - 1
        (the swap ruined the heap property, so restore it)
        siftDown(a, 0, end)
(Put elements of 'a' in heap order, in-place)
procedure heapify(a, count) is
    (start is assigned the index in 'a' of the last parent node)
    (the last element in a 0-based array is at index count-1; find the parent of that element)
    start ← floor ((count - 2) / 2)
    
    while start ≥ 0 do
        (sift down the node at index 'start' to the proper place such that all nodes below
         the start index are in heap order)
        siftDown(a, start, count - 1)
        (go to the next parent node)
        start ← start - 1
    (after sifting down the root all nodes/elements are in heap order)

(Repair the heap whose root element is at index 'start', assuming the heaps rooted at its children are valid)
procedure siftDown(a, start, end) is
    root ← start

    while root * 2 + 1 ≤ end do    (While the root has at least one child)
        child ← root * 2 + 1       (Left child)
        swap ← root                (Keeps track of child to swap with)

        if a[swap] < a[child]
            swap ← child
        (If there is a right child and that child is greater)
        if child+1 ≤ end and a[swap] < a[child+1]
            swap ← child + 1
        if swap = root
            (The root holds the largest element. Since we assume the heaps rooted at the
             children are valid, this means that we are done.)
            return
        else
            swap(a[root], a[swap])
            root ← swap            (repeat to continue sifting down the child now)

Java实现

 

 1     public void heapsort(int[] a, int count) {
 2         if (count < 2)
 3             return;
 4         heapify(a, count);
 5         int end = count - 1;
 6         while (end > 0) {
 7             swap(a, 0, end);
 8             end--;
 9             siftdown(a, 0, end);
10         }
11     }
12     public void heapify(int[] a, int count) {
13         int start = (count - 2) / 2;
14         while (start >= 0) {
15             siftdown(a, start, count - 1);
16             start--;
17         }
18     }
19     public void siftdown(int[] a, int start, int end) {
20         int root = start;
21 
22         while (root * 2 + 1 <= end) {
23             int child = root * 2 + 1;
24             int swap = root;
25 
26             if (a[swap] < a[child]) {
27                 swap = child;
28             }
29             if (child + 1 <= end && a[swap] < a[child + 1]) {
30                 swap = child + 1;
31             }
32             if (root == swap) {
33                 return;
34             } else {
35                 swap(a, root, swap);
36             }
37             root = swap;
38         }
39     }
40     public void swap(int[] a, int i, int j) {
41         int t = a[i];
42         a[i] = a[j];
43         a[j] = t;
44     }

 

posted @ 2015-08-17 01:59  lenbkan  阅读(2654)  评论(0编辑  收藏  举报