当前位置: 首页 > wzjs >正文

网站建设合同书样本建设通查项目经理

网站建设合同书样本,建设通查项目经理,wordpress增加连接池,建立平台的步骤在数据结构中,堆(Heap)是一种特殊的树形数据结构,通常用于实现优先队列。堆分为最大堆和最小堆两种类型。最大堆的每个节点的值都大于或等于其子节点的值,而最小堆的每个节点的值都小于或等于其子节点的值。Java 提供了…

_20250228231939.jpg

在数据结构中,堆(Heap)是一种特殊的树形数据结构,通常用于实现优先队列。堆分为最大堆和最小堆两种类型。最大堆的每个节点的值都大于或等于其子节点的值,而最小堆的每个节点的值都小于或等于其子节点的值。Java 提供了 PriorityQueue 类来实现堆的功能。

堆的介绍

堆(Heap)是一种满足特定条件的完全二叉树,主要分为两种:如下图所示:

  • 小顶堆:每个节点的值都小于或等于其子节点的值。
  • 大顶堆:每个节点的值都大于或等于其子节点的值。

_20250228220306.jpg

  1. 特性:
  • 最底层的节点靠左填充,其它层的节点都被填满
  • 根节点称为堆顶,最底层最靠右的节点称为堆底
  • 堆的根节点(堆顶)是堆中最大(大顶堆)或最小(小顶堆)的元素。
  1. 堆的存储

堆通常使用数组来存储。对于一个索引为 i 的节点:

  • 其左子节点的索引为 2i + 1

  • 其右子节点的索引为 2i + 2

  • 其父节点的索引为 (i - 1) / 2

  1. 堆的操作及效率

java中提供的是优先队列(PriorityQueue)

方法名描述时间复杂度
add()元素入堆O(log n)
poll()堆顶元素出堆O(log n)
peek()访问堆顶元素O(1)
size()获取堆中元素的数量O(1)
isEmpty()堆是否为空O(1)

堆排序

堆排序(Heap Sort)是一种基于堆数据结构的比较排序算法。它的时间复杂度为 O ( n l o g n ) O(nlogn) O(nlogn),并且是一种原地排序算法(即不需要额外的存储空间)。堆排序的核心思想是利用堆的性质来维护一个最大堆或最小堆,然后逐步将堆顶元素(最大值或最小值)取出,放到数组的末尾,最终得到一个有序的数组。

堆排序的基本步骤

  1. 构建最大堆

从最后一个非叶子节点开始,向前遍历每个节点,对每个节点执行堆化操作。

最后一个非叶子节点的索引为 n/2 - 1,其中 n 是数组的长度。

  1. 排序

将堆顶元素(最大值)与堆的最后一个元素交换。(出堆)

将堆的大小减一(即忽略最后一个元素)。

对新的堆顶元素执行堆化操作,以维持最大堆的性质。

重复上述步骤,直到堆的大小为1。

代码实现如下:

/*** 堆排序*/
public class HeapSort {public static void heapSort(int[] arr) {int n = arr.length;//  构建大顶堆for (int i = n / 2 - 1; i >= 0; i--) {heapify(arr, n, i);}// 2. 排序for (int i = n - 1; i > 0; i--) {// 将堆顶元素(最大值)与当前堆的最后一个元素交换int temp = arr[0];arr[0] = arr[i];arr[i] = temp;// 对新的堆顶元素进行堆化操作heapify(arr, i, 0);}}//堆化操作public static void heapify(int[] arr,int n,int i){int max = i; // 初始化最大值为当前节点int left = 2 * i + 1; // 左子节点int right = 2 * i + 2; // 右子节点// 如果左子节点大于当前最大值,则更新最大值if (left < n && arr[left] > arr[max]) {max = left;}// 如果右子节点大于当前最大值,则更新最大值if (right < n && arr[right] > arr[max]) {max = right;}// 如果最大值不是当前节点,则交换并继续堆化if (max != i) {int swap = arr[i];arr[i] = arr[max];arr[max] = swap;// 递归地对子树进行堆化heapify(arr, n, max);}}public static void main(String[] args) {int[] arr = {8, 10, 7, 4, 6, 2, 5, 1};heapSort(arr);System.out.println(Arrays.toString(arr));}
}

堆排序特性

  • 时间复杂度为 O ( n l o g n ) O(nlogn) O(nlogn)、非自适应排序

建堆操作适用时间O(n),从堆中提取最大元素时间O(logn),共n-1轮。

  • 空间复杂度为O(1)、原地排序

元素堆化和堆操作都是在原数组上进行的。

  • 非稳定排序

在交换堆顶元素和堆底元素时,相等元素的相对位置可能发生了改变。

优缺点

  1. 优点
  • 时间复杂度较低,适合大规模数据排序。

  • 原地排序,不需要额外的存储空间。

  1. 缺点
  • 不稳定排序算法(相同元素的相对顺序可能改变)。

  • 对于小规模数据,性能不如插入排序等简单算法。

总结

堆排序是一种高效的排序算法,尤其适用于需要原地排序的场景。它的时间复杂度为O(nlogn),并且不需要额外的存储空间。堆排序的核心在于堆化操作,通过维护堆的性质来实现排序。

http://www.dtcms.com/wzjs/590823.html

相关文章:

  • 建设小网站教程扬中吧百度贴吧
  • 做网站哪个公司比较好网站主机哪买
  • 深圳网站建设企导航网站移动端流量占比
  • 当当网网站建设步骤网页制作需要学多久
  • 网站建设实训个人总结1000字上海营销型网站建设价格
  • 建设工程质量安全管理体系网站做网站的人搞鬼少首页文件
  • 商务网站建设管理思路网站建设教学视频
  • 菏泽正耀网站建设公司怎么样网站布局的好坏的几个要素
  • 做网站六安企业网站建设存在的不足与困难
  • 做有网被视频网站seo词库排行
  • 深圳网络营销网站免费注册网站大全
  • 钢结构网站建设域名网站查询
  • 制作个人网站步骤网站建设需要多少钱小江网页设计
  • 深圳网站建设服务器公司豪柏大厦做网站的公司
  • 上海人才网官网站首页邯郸网络营销推广平台
  • 网站内页布局的不同常德公交网站
  • 常德网站建设厦门网站制作wordpress主题在哪里
  • 营销单页模板网站莱芜做网站的商家有哪些
  • 个人网站建设咨询电话外贸数据分析网站
  • 微信如何做有趣的短视频网站计算机类专业包括哪些
  • 找个免费的网站千图app的优势
  • 网站内部链接的作用有哪些桂林哪里学建设网站
  • 湖南网站seo推广网络系统集成工程师
  • 汕头市专注网站建设建设银行手机网站首页
  • 网站设计的含义php靓号网站源码
  • 一个做网站的团队需要哪些人员wordpress 外跳
  • 做印刷的网站长沙做网站seo公司
  • 济宁建设局网站首页网站建设结构分布
  • 做游戏的外包网站网站开发基础语言
  • 网站开发全过程四川建设厅网站复查中