温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java排序算法之堆排序如何实现

发布时间:2021-11-24 11:10:35 来源:亿速云 阅读:202 作者:小新 栏目:开发技术

这篇文章主要介绍了Java排序算法之堆排序如何实现,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

二叉堆是完全二叉树或者是近似完全二叉树。
二叉堆满足二个特性︰

1.父结点的键值总是大于或等于(小于或等于)任何一个子节点的键值。

2.每个结点的左子树和右子树都是一个二叉堆(都是最大堆或最小堆)。

任意节点的值都大于其子节点的值——大顶堆(最后输出从小到大排)
任意节点的值都小于其子节点的值———小顶堆(最后输出从大到小排)

堆排序步骤

1.堆化,反向调整使得每个子树都是大顶或者小顶堆(建堆)
2.按序输出元素∶把堆顶和最末元素对调,然后调整堆顶元素(排序)

堆排序代码实现(大顶堆)

public class HeapSort {     private static void heapSort(int[] arr) {         // 构造初始堆(大顶堆),从第一个非叶子节点开始调整,左右孩子节点中较大的交换到父节点中         for (int i = arr.length / 2 - 1; i >= 0; i--) {             heapAdjust(arr, i, arr.length);         }         // 调整堆结构,交换堆顶元素与末尾元素         for (int j = arr.length - 1; j > 0; j--) {             swap(arr, 0, j);// 将堆顶元素与末尾元素进行交换             heapAdjust(arr, 0, j);// 重新对堆进行调整         }     }       private static void swap(int[] arr, int a, int b) {         int temp = arr[a];         arr[a] = arr[b];         arr[b] = temp;     }       // 调整大顶堆     private static void heapAdjust(int[] arr, int i, int len) {         int temp = arr[i], index = 2 * i + 1;         while (index < len) {             if (index + 1 < len && arr[index] < arr[index + 1]) {// 如果左子结点小于右子结点,index指向右子结点                 index += 1;             }             if (arr[index] > temp) {// 如果子节点大于父节点,将子节点值赋给父节点                 arr[i] = arr[index];                 i = index;                 index = 2 * i + 1;             } else {                 break;             }         }         arr[i] = temp;     }       public static void main(String[] args) {         int[] arr = {1,28,3,21,11,7,6,18};         heapSort(arr);         System.out.println(Arrays.toString(arr));     } }

时间复杂度:O(nlogN)

感谢你能够认真阅读完这篇文章,希望小编分享的“Java排序算法之堆排序如何实现”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI