首页 > 作文

Java 十大排序算法之堆排序刨析

更新时间:2023-04-03 22:35:41 阅读: 评论:0

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

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; 淘宝分期付款           } el {                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 十大排序算法之堆排序刨析的文章就介绍到这了,更多相关java 堆排序内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-03 22:35:40,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/4e0b32f2d360528a2bcc275e60a1de17.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:Java 十大排序算法之堆排序刨析.doc

本文 PDF 下载地址:Java 十大排序算法之堆排序刨析.pdf

标签:节点   子树   结点   元素
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图