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

杭州开发区建设局网站品牌推广的渠道有哪些

杭州开发区建设局网站,品牌推广的渠道有哪些,电商网站有哪些功能模块,网站建设结单 优帮云题目描述 实现思路 要实现一个堆,我们首先要了解堆的概念。 堆是一种完全二叉树,分为大顶堆和小顶堆。 大顶堆:每个节点的值都大于或等于其子节点的值。 小顶堆:每个节点的值都小于或等于其子节点的值。 完全二叉树&#xff…

题目描述

实现思路

要实现一个堆,我们首先要了解堆的概念。

堆是一种完全二叉树,分为大顶堆和小顶堆。

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

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

完全二叉树:在一颗二叉树中,若除最后一层外的其余层都是满的,并且最后一层要么是满的,要么在右边缺少连续若干节点。

回到原题,实现一个大顶堆,使用数组作为底层数据结构,并提供以下操作:

  • 添加元素(add):向堆中添加一个元素。

  • 删除堆顶元素(poll):删除并返回堆顶元素(即最大值)。

 

首先我们需要明白一个事:

jdk提供的堆结构,也就是PriorityQueue优先级队列,删除堆顶元素(remove(),poll()),会进行下

沉操作,向最后插入元素(add(),offer()),会进行上浮操作,因为有这两个操作,所以在堆中,删除

堆顶元素,向最后插入元素不会改变堆结构。

但是向堆的中间进行插入或修改,就会改变堆结构,不会自己调整

所以我们实现堆,也得需要实现上浮和下沉操作

并且在上浮和下沉过程中,还需要交换元素,所以我们还需要实现一个数组中元素交换的函数

代码实现

	class MaxHeap{//存储堆中元素的数组int[] heap;//堆中元素的个数int size;//堆的初始容量,超出容量,add函数里2倍扩容int capacity;public MaxHeap(int capacity) {this.capacity = capacity;heap = new int[capacity];size = 0;}public void add(int value) {//判断是否需要扩容if(size == capacity) {capacity = capacity * 2;int[] newHeap = new int[capacity];System.arraycopy(heap,0,newHeap,0,size);heap = newHeap;}heap[size] = value;size++;heapifyUp();}//上浮操作,维持堆的性质public void heapifyUp() {//当前节点对应在数组中的索引int index = size - 1;//父节点的在数组中的索引 -- 只能有一个父节点int parentIndex = (index - 1) / 2;while(parentIndex >= 0 && heap[parentIndex] < heap[index]) {swap(heap,parentIndex,index);index = parentIndex;parentIndex = (index - 1) / 2;}}//删除并返回堆顶元素public int poll() {//判断堆中是否有元素if(size == 0) {return Integer.MIN_VALUE;}int maxValue = heap[0];heap[0] = heap[size - 1];size--;heapifyDown();return maxValue;}//下沉操作,维持堆的性质public void heapifyDown() {int index = 0;//一个节点有两个子节点int leftChildIndex = 2 * index + 1;int rightChildIndex = 2 * index + 2;while(leftChildIndex < size) {//找到左右子节点中比较大的那个int largerChildIndex = leftChildIndex;if(rightChildIndex < size && heap[rightChildIndex] > heap[leftChildIndex]) {largerChildIndex = rightChildIndex;}//如果当前节点大于等于最大的子节点,堆性质已经满足if(heap[index] >= heap[largerChildIndex]) {break;}swap(heap,index,largerChildIndex);index = largerChildIndex;leftChildIndex = 2 * index + 1;rightChildIndex = 2 * index + 2;}}public void swap(int[] nums,int i,int j) {int temp = nums[i];nums[i] = nums[j];nums[j] = temp;}}

类似题目

【模板】堆_牛客题霸_牛客网
215. 数组中的第K个最大元素 - 力扣(LeetCode)

http://www.khdw.cn/news/63402.html

相关文章:

  • 企业做网站用dedeCMS免费吗宁波网络营销有哪些
  • 做多语言网站多少钱营销手机都有什么功能啊
  • 网站建设时关键词要怎么选呢网站seo优化方案项目策划书
  • 网站 数据报表如何做站长工具查询seo
  • 西宁高端网站建设网络广告策划
  • 购物网站简介安卓优化清理大师
  • 宝鸡品牌网站建设在线seo优化工具
  • 网站管理员怎么登陆长沙网站建设服务
  • 用别的公司域名做网站seo交流论坛
  • 那个网站做网编好如何刷关键词指数
  • 网络平台搭建网站seo报价
  • 职业病院网站建设常见的网络营销工具
  • 网站制作xiu021b站推广怎么买
  • 上海 网站公安备案服务器ip域名解析
  • 网上申报税务操作流程视频教程seo没什么作用了
  • 怎样做一个网站赚钱吗网站seo谷歌
  • 深圳做微藻的公司网站网店seo关键词
  • 徐州企业做网站世界足球世界排名
  • 咸宁商城网站建设网络销售推广是做什么的具体
  • 壹佰网站建设google play谷歌商店
  • 毕业设计 网站建设选题网页设计怎么做
  • 抄袭别人网站的前端代码合法吗百度sem推广
  • 如何做博客网站网络营销的整体概念
  • 泉州企业建站模板cba最新排名
  • 做红包网站是犯法的吗今日国内新闻最新消息10条
  • 苏州注册公司代理公司seo产品优化免费软件
  • 做个网站多钱互联网推广的优势
  • 网站建设公众号小程序推广开发电商推广平台
  • 淄博企业网站建设哪家专业怎么申请网站空间
  • 国内外知名建设设计网站链友咨询