算法-->堆排序
2018-04-11 03:32
190 查看
感觉写的不是很好,自己的思绪还是有点乱。
package 堆排序; public class DuiPai { static final int SIZE = 10; static void heapSort(int a[], int n) { int i, j, h, k; int t; // 将a[0,n-1]建立成为一个大根堆 for (i = n / 2 - 1; i >= 0; i--) { // 第i个节点又右子树 while (2 * i + 1 < n) { j = 2 * i + 1; if (j + 1 < n) { // 右左子树小于右字树,则需要比较右子树 if (a[j] < a[j + 1]) j++;// 序号增加1,指向右子树 } // 比较i和j为序号的数据 if (a[i] < a[j]) { // 交换数据 t = a[i]; a[i] = a[j]; a[j] = t; // 此时堆被破坏了,需要重新调整 i = j; } else { break; } } // 输出构成的堆 System.out.println("源数据构成的堆:"); for (h = 0; h < n; h++) { System.out.print(" " + a[h]);// 输出 } System.out.print("\n"); for (i = n - 1; i > 0; i--) { t = a[0];// 与第i个记录进行交换 a[0] = a[i]; a[i] = t; k = 0; while (2 * k + 1 < i) { j = 2 * k + 1; if (j + 1 < i) { // 右左子树小于右字树,则需要比较右子树 if (a[j] < a[j + 1]) { j++;// 序号增加1,指向右子树 } } if (a[k] < a[j]) { // 交换数据 t = a[k]; a[k] = a[j]; a[j] = t; // 此时比较左右子节点都大堆被破坏了,不再重新调整 k = j; } else { break; } } // 输出构成的堆 System.out.println("第:" + (n + 1) + "步排序结果是"); for (h = 0; h < n; h++) { System.out.print(" " + a[h]);// 输出 } System.out.print("\n"); } } } public static void main(String[] args) { DuiPai dd = new DuiPai(); int[] shuzu = new int[SIZE]; int i; for (i = 0; i < SIZE; i++) { shuzu[i] = (int) (100 + Math.random() * (100 + 1)); } System.out.print("排序前的数组为:\n"); for (i = 0; i < SIZE; i++) { System.out.print(shuzu[i] + " "); } System.out.print("\n"); heapSort(shuzu, SIZE); System.out.print("排序后的数组为:\n"); for (i = 0; i < SIZE; i++) { System.out.print(shuzu[i] + " "); } } }
相关文章推荐
- <菜鸟学算法-A排序(分治的思想:堆排序)>
- 白话经典算法系列之七 堆与堆排序
- 算法之旅,直奔<algorithm>之一 all_of
- 算法之旅,直奔<algorithm>之四 binary_search
- 【算法导论】堆排序
- <菜鸟学算法-Dijkstra求最短路径>
- 【基础算法】- 堆排序
- 算法之旅,直奔<algorithm>之十 count_if
- 两种常用的选择排序算法--简单选择排序、堆排序
- 算法之旅,直奔<algorithm>之十四 fill_n
- 【更新】排序算法比较:插入排序,冒泡排序,归并排序,堆排序,快速排序,计数排序,基数排序,桶排序
- Java与算法之(8) - 堆排序
- 基本算法:堆排序
- 吾爱破解2012CM大赛 -> 易 -> fywy 注册算法分析
- 【算法导论】C++参考源码之堆排序中的优先级队列
- 求质数算法的N种境界 (N > 10)
- 白话经典算法系列之七 堆与堆排序
- <<一种基于δ函数的图象边缘检测算法>>一文算法的实现。
- 算法之旅,直奔<algorithm>之二十二 sort
- 蓝桥杯算法训练<一>