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

做动态图片下载哪个网站好公司产品怎样网上推广

做动态图片下载哪个网站好,公司产品怎样网上推广,本地视频做成链接网址,网站建设优化石家庄前言 之前已经说过堆的特点了,具体文章在数据结构与算法【队列】的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.tj-hxxt.cn/news/96301.html

相关文章:

  • 做购物网站多少钱百度seo营销
  • css网站模板下载最新足球消息
  • 汉中做网站的公司seo关键词优化报价
  • 网站流量钱是谁给的优化培训内容
  • 网站制作理念福州网站优化
  • 新手用什么程序建网站账号权重查询入口
  • 怎么建立博客网站自媒体视频剪辑培训班
  • 国外获奖网站个人网页在线制作
  • 梧州单身相亲网站怎么做微信推广和宣传
  • 长清治做网站百度如何收录网站
  • 巩义移动网站建设上海牛巨微seo优化
  • 网站获取访客qq号网站备案查询工信部
  • 中国建设银行网站特点专业seo关键词优化
  • 字体网站广州知名网络推广公司
  • 建立个网站徐州百度搜索网站排名
  • WordPress获取用户密码网站优化seo
  • 广州的一起做网站必应收录提交入口
  • 个人网站制作步骤seo工具
  • b2c网站建设 杭州推广普通话文字素材
  • 上海品牌网站制作windows优化大师官方下载
  • 做58网站怎么赚钱百度关键词优化平台
  • 做三年网站需要多少钱seo公司厦门
  • 贵阳网站制作 建设百度seo优化培训
  • 网站设计公司 南京百度信息流广告推广
  • 和创客贴类似的网站手机如何制作网页
  • 做外贸自己做网站么网络舆情监测系统软件
  • 网站怎做百度代码统计天津百度百科
  • 网站建设教程简笔画什么广告推广最有效果
  • wordpress首饰商城系统如何优化网站
  • ps企业站网站做多大的公众号关键词排名优化