首页 > 其他 > 详细

第六章 堆排序

时间:2014-06-10 11:57:07      阅读:327      评论:0      收藏:0      [点我收藏+]

以后尽量能用迭代就别用递归啊,递归只是让自己轻松了,但是却增加了电脑的负担。

bubuko.com,布布扣
package chap06_Heap_Sort;

import static org.junit.Assert.*;

import java.util.Arrays;

import org.junit.Test;

public class SortAlorithms {
    /**
     * 返回当前下标下父节点的下标
     * 
     * @param i
     * @return
     */
    protected static int parent(int i) {
        if (i == 0)
            return i;
        return (i - 1) / 2;
    }

    /**
     * 返回i的对应左子节点下标
     * 
     * @param i
     * @return
     */
    protected static int left(int i) {
        return 2 * i + 1;
    }

    /**
     * 返回i对应右子节点下标
     * 
     * @param i
     * @return
     */
    protected static int right(int i) {
        return 2 * (i + 1);
    }

    /**
     * 维护最大堆性质(递归方法实现) 容易内存溢出
     * 
     * @param a
     * @param i
     */
    protected static void maxHeapify1(int[] a, int i, int SIZE) {
        int l = left(i);
        int r = right(i);
        int tmp;
        if (l < SIZE & r < SIZE) {
            if (a[i] >= a[l] & a[i] >= a[r])
                return;
            else if (a[l] > a[r]) {
                tmp = a[i];
                a[i] = a[l];
                a[l] = tmp;
                i = l;
            } else {
                tmp = a[i];
                a[i] = a[r];
                a[r] = tmp;
                i = r;
            }
        } else if (l < SIZE) {
            if (a[i] < a[l]) {
                tmp = a[i];
                a[i] = a[l];
                a[l] = tmp;
                i = l;
            }
        } else {
            return;
        }
        maxHeapify1(a, i, SIZE);
    }

    /**
     * 重建最大堆,从i开始到size(不包含size索引)
     * 
     * @param a
     * @param i
     * @param SIZE
     */
    protected static void maxHeapify(int[] a, int i, int SIZE) {
        int l = left(i);
        int r = right(i);
        int tmp;
        while (l < SIZE & r < SIZE) {
            if (a[i] >= a[l] & a[i] >= a[r])
                return;
            else if (a[l] > a[r]) {
                tmp = a[i];
                a[i] = a[l];
                a[l] = tmp;
                i = l;
            } else {
                tmp = a[i];
                a[i] = a[r];
                a[r] = tmp;
                i = r;
            }
            l = left(i);
            r = right(i);
        }
        if (l < SIZE) {
            if (a[i] < a[l]) {
                tmp = a[i];
                a[i] = a[l];
                a[l] = tmp;
                i = l;
            }
        }
        return;
    }

    /**
     * 将数组a转换成最大堆,不要用递归方法,尽量用迭代方法实现
     * 
     * @param a
     */
    protected static void buildMaxHeap(int[] a) {
        int n = a.length;

        for (int i = n / 2; i >= 0; i--) {
            maxHeapify1(a, i, n);
        }
    }

    /**
     * 堆排序
     * 
     * @param n
     */
    static void heapSort(int[] n) {
        buildMaxHeap(n);
        int l = n.length;
        int size = l;
        int tmp;
        for (int i = l - 1; i > 0; i--) {
            tmp = n[0];
            n[0] = n[i];
            n[i] = tmp;
            size--;
            maxHeapify(n, 0, size);
        }
    }

    @Test
    public void testName() throws Exception {
        // int[] a = { 2, 5, 3, 7, 8, 12, 0, 2, 45, 32 };
        int[] a = { 4, 1, 3, 2, 16, 9, 10, 14, 8, 7 };
        // buildMaxHeap(a);
        // heapSort(a);
        maxHeapify1(a, 0, 10);
        System.out.println(Arrays.toString(a));
    }
}
bubuko.com,布布扣

第六章 堆排序,布布扣,bubuko.com

第六章 堆排序

原文:http://www.cnblogs.com/xiaojintao/p/3778975.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!