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

做违法网站培训前端网站开发

做违法网站,培训前端网站开发,免费源码html网站,wordpress 登出函数前言 之前已经说过堆的特点了,具体文章在数据结构与算法【队列】的Java实现-CSDN博客。因此直接实现堆的其他功能。 建堆 所谓建堆,就是将一个初始的堆变为大顶堆或是小顶堆。这里以大顶堆为例。展示如何建堆。 找到最后一个非叶子节点从后向前&…

前言 

之前已经说过堆的特点了,具体文章在数据结构与算法【队列】的Java实现-CSDN博客。因此直接实现堆的其他功能。

建堆

所谓建堆,就是将一个初始的堆变为大顶堆或是小顶堆。这里以大顶堆为例。展示如何建堆。

  1. 找到最后一个非叶子节点
  2. 从后向前,对每个节点执行下潜

一些规律(0作为根节点时满足)

  • 一棵满二叉树节点个数为 2^h-1,如下例中高度 h=3 节点数是 2^3-1=7
  • 非叶子节点范围为 [0, size/2-1]

建堆的时间复杂度为O(n)。

一个基础的大顶堆实现代码如下

public class MaxHeap {int[] array;int size;public MaxHeap(int capacity) {this.array = new int[capacity];}public MaxHeap(int[] array) {this.array = array;this.size = array.length;heapify();}/*** 获取堆顶元素** @return 堆顶元素*/public int peek() {return array[0];}/*** 删除堆顶元素** @return 堆顶元素*/public int poll() {int top = array[0];swap(0, size - 1);size--;down(0);return top;}/*** 删除指定索引处元素** @param index 索引* @return 被删除元素*/public int poll(int index) {int deleted = array[index];up(Integer.MAX_VALUE, index);poll();return deleted;}/*** 替换堆顶元素** @param replaced 新元素*/public void replace(int replaced) {array[0] = replaced;down(0);}/*** 堆的尾部添加元素** @param offered 新元素* @return 是否添加成功*/public boolean offer(int offered) {if (size == array.length) {return false;}up(offered, size);size++;return true;}// 将 offered 元素上浮: 直至 offered 小于父元素或到堆顶private void up(int offered, int index) {int child = index;while (child > 0) {int parent = (child - 1) / 2;if (offered > array[parent]) {array[child] = array[parent];} else {break;}child = parent;}array[child] = offered;}// 建堆private void heapify() {// 如何找到最后这个非叶子节点  size / 2 - 1for (int i = size / 2 - 1; i >= 0; i--) {down(i);}}// 将 parent 索引处的元素下潜: 与两个孩子较大者交换, 直至没孩子或孩子没它大private void down(int parent) {int left = parent * 2 + 1;int right = left + 1;int max = parent;if (left < size && array[left] > array[max]) {max = left;}if (right < size && array[right] > array[max]) {max = right;}if (max != parent) { // 找到了更大的孩子swap(max, parent);down(max);}}// 交换两个索引处的元素private void swap(int i, int j) {int t = array[i];array[i] = array[j];array[j] = t;}
}
http://www.15wanjia.com/news/174175.html

相关文章:

  • 网站推广的方式和方法公司网站建设30元
  • 安吉哪里做网站好昆明小程序制作
  • 推荐专业的外贸建站公司用户注册
  • 商城网站项目案例那个网站可以找人做设计
  • 网站设计好了如何上传到自己搭建的网上去黄冈网站建设收费
  • 自考网站建设与实践北京手工活外发加工网
  • 化工网站源码天辰建设信息网
  • 个人商城网站能备案吗企业所得税征收方式
  • 网站哪里可以查到做ddoswordpress在哪里输入统计代码
  • 网站seo推广计划三亚网站建设美工
  • 什么网站可以做头像linux wordpress nginx
  • 建网站需要怎样做上海中建建筑设计院有限公司
  • 网站 多语言处理广州招聘网
  • 最全的数据网站装修公司展厅效果图设计图片
  • 网站建设建设公司资质要求上海制作网页的公司有哪些
  • 建网站找哪家好做的高大上的网站
  • 网站建设中倒计时源码移动网站开发技术
  • 池州商城网站开发wordpress 无法自定义
  • 闵行做网站公司铝棒易站公司查看网站外链代码
  • 永久免费域名注册网站wordpress网站上线
  • 网站举报影视文化传媒公司网站建设
  • 整站seo公司wordpress自动水印
  • 手机端网站开发流程北京官方网站建设
  • 商城网站的seo优化改怎么做标书制作培训课程
  • 网站正在建设中 动态app开发属于什么行业
  • 小程序网站开发者利济南网站制作经验
  • 做爰全过程网站免费的视频外包加工平台
  • 怎样创建音乐网站申请新账号 免费
  • 重庆邮电大学官网网站发布产品的免费平台有哪些
  • 林芝做网站网站 栏目管理