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

企业网站的建设哪家比较好科研实验室网站建设

企业网站的建设哪家比较好,科研实验室网站建设,在建设部网站呢李可以看出需要什么时候考试,文化公司网站建设目录 1.堆的概念 2.堆性质堆中的某个元素小于或大于他的左右孩子 3.小根堆实例 4.堆创建 4.1调整思路 4.2向下调整思路 4.3代码实现(大根堆) 5.堆的删除 6.堆的插入 7.常用接口 7.1PriorityQueue和PriorityBlockingQueue 1.堆的概念 如果有一…

目录

1.堆的概念

2.堆性质堆中的某个元素小于或大于他的左右孩子

3.小根堆实例

4.堆创建

4.1调整思路

4.2向下调整思路

4.3代码实现(大根堆)

5.堆的删除

6.堆的插入

7.常用接口

7.1PriorityQueue和PriorityBlockingQueue


1.堆的概念

如果有一个关键码的集合K{k0,k1,k2,......kn},把他所有的元素按照二叉树的存储方式存储,在一个一维数组李,满足:ki<=2*ki-1且ki<2*ki-1+1,则称之为小根堆,反之称为大根堆。

2.堆性质
堆中的某个元素小于或大于他的左右孩子

堆是一个完全二叉树

3.小根堆实例

101556253070

存储结构图

逻辑结构图

补充:

已知孩子节点是2*i+1 或者 2*i,则父亲节点是i

如果2*i+1大于数组长度则没有右孩子

如果i=0,则没有左右孩子,该节点是根节点

4.堆创建

向下调整:

27151918283465492537

4.1调整思路

从最后一颗数开始调整,每颗数都经过向下调整最终得到一个大根堆或者小根堆

4.2向下调整思路

1.首先让parent标记要调整的节点,child标记parent的左孩子(基于完全二叉树的性质,如果有孩子一定是先有左孩子)

2.如果parent的左孩子存在,即child<arr.length,在判断是否存在有孩子,如果存在判断右孩子是不是比左孩子大,若存在右孩子并且右孩子大于左孩子,则换成右孩子,最后将child和parent比较,如果要要构成大根堆:child大于parent则交换值,parent=child,child=parent*2+1继续向下调整;反之说明这颗树已经是一个大根堆的不需调整,进入下一个树的调整;如果要要构成小根堆:child小于于parent则交换值,parent=child,child=parent*2+1继续向下调整,反之说明这颗树已经是一个小根堆的不需调整,进入下一个树的调整;

根据实例得出的每一调整的顺序:

[27, 15, 19, 49, 37, 34, 65, 18, 25, 28]
[27, 15, 65, 49, 37, 34, 19, 18, 25, 28]
[27, 15, 65, 49, 37, 34, 19, 18, 25, 28]
[27, 49, 65, 25, 37, 34, 19, 18, 15, 28]
[27, 49, 65, 25, 37, 34, 19, 18, 15, 28]
[65, 49, 34, 25, 37, 27, 19, 18, 15, 28]
[65, 49, 34, 25, 37, 27, 19, 18, 15, 28]
[65, 49, 34, 25, 37, 27, 19, 18, 15, 28]


最终得到:

4.3代码实现(大根堆)

package sort;/*** @author starsea* @date 2024-06-24 13:02*/import com.sun.org.apache.bcel.internal.generic.SWAP;import java.util.Arrays;/*** 时间复杂度:O(N)* 空间复杂度:O(1)* 稳定性:不稳定*/
public class HeapSort {public static void main(String[] args) {int[] arr = {27, 15, 19, 18, 28, 34, 65, 49, 25, 37};createHeap(arr);}public static void createHeap(int[] arr) {int len = arr.length;for (int i = len - 1; i >= 0; i--) {int parent = (i - 1) / 2;siftDwon(arr, parent);System.out.println(Arrays.toString(arr));}}public static void siftDwon(int[] arr, int parent) {int child = parent * 2 + 1;while (child < arr.length) {if (child + 1 < arr.length && arr[child + 1] > arr[child]) {child++;}if (arr[parent] < arr[child]) {swap(arr, parent, child);parent = child;child = parent * 2 + 1;} else {break;}}}public static void swap(int[] arr, int i, int j) {int tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;}
}

5.堆的删除

1.从堆顶删除

思路:交换队尾和对堆头的元素,然后usedSize--,再次调整

package sort;/*** @author starsea* @date 2024-06-24 13:02*/import com.sun.org.apache.bcel.internal.generic.BranchHandle;
import com.sun.org.apache.bcel.internal.generic.SWAP;import java.util.Arrays;/*** 时间复杂度:O(N*log^N)* 空间复杂度:O(1)* 稳定性:不稳定*最后一位放的是删除元素*/
public class HeapSort {//删除堆头元素:1.交换堆头堆尾元素,2.usedsize减一3.再次调整public static void deleteElemt(int[] arr){int len=arr.length;swap(arr,0,len-1);for (int i = len-2; i >= 0; i--) {int parent = (i - 1) / 2;//siftDwon(arr, parent);siftUp(arr,i,len-2);// System.out.println("向下调整的每一步:"+Arrays.toString(arr));System.out.println("删除调整的每一步:"+Arrays.toString(arr));}}}

2.从堆尾删除

思路:直接usedSize--

6.堆的插入

思路放到尾巴上,然后向上调整

package sort;/*** @author starsea* @date 2024-06-24 13:02*/import com.sun.org.apache.bcel.internal.generic.BranchHandle;
import com.sun.org.apache.bcel.internal.generic.SWAP;import java.util.Arrays;/*** 时间复杂度:O(N*log^N)* 空间复杂度:O(1)* 稳定性:不稳定*/
public class HeapSort {public static void main(String[] args) {int[] arr = {27, 15, 19, 18, 28, 34, 65, 49, 25, 37};createHeap(arr,80);}public static void createHeap(int[] arr,int elemt) {int len = arr.length;//扩容arr=Arrays.copyOf(arr,arr.length*2);arr[len++]=elemt;for (int i = len-1; i >= 0; i--) {int parent = (i - 1) / 2;//siftDwon(arr, parent);siftUp(arr,i,len);// System.out.println("向下调整的每一步:"+Arrays.toString(arr));System.out.println("向上调整的每一步:"+Arrays.toString(arr));}}
//向下调整public static void siftDwon(int[] arr, int parent) {int child = parent * 2 + 1;while (child < arr.length) {if (child + 1 < arr.length && arr[child + 1] > arr[child]) {child++;}if (arr[parent] < arr[child]) {swap(arr, parent, child);parent = child;child = parent * 2 + 1;} else {break;}}}//向上调整public static void  siftUp(int[] arr,int child,int usedSize){int parent=(child-1)/2;while (child>0){if(child+1<usedSize && arr[child+1]>arr[child]){child++;}if(arr[child]>=arr[parent]){swap(arr,child,parent);child=parent;parent=(child-1)/2;}else{break;}}}public static void swap(int[] arr, int i, int j) {int tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;}
}

7.常用接口

7.1PriorityQueue和PriorityBlockingQueue

PriorityQueuey是线程不安全的而PriorityBlockingQueue是线程安全的。

7.2使用

//包
import java.util.PriorityQueue;riorityQueue<Integer> priorityQueue=new PriorityQueue<>();

注意:

  1. 插入的对象必须是可比较的
  2. 不能为空
  3. 没有容量限制
  4. 底层使用了堆
  5. 默认是小根堆 
http://www.yayakq.cn/news/839446/

相关文章:

  • 如何在百度上搜索到自己的网站建站公司怎么接单
  • 天翼云主机 网站wordpress网站翻译插件
  • 餐厅网站建设文案书品古典家具网站模板
  • 路灯东莞网站建设网站服务器安全防护
  • 在哪里可以建网站南阳企业网站seo
  • 公司禁用网站怎么做网站添加字体
  • 帝国cms获取网站地址网页搜索关键词快捷键
  • 唐山自助网站建设系统网站开发项目需要什么人员
  • 织梦网站去除技术支持门户网站设计技巧
  • 营销型网站代理上门做睫毛哪个网站
  • 做尾货的网站太原做网站培训
  • 青岛营销型网站做推广网站有什么
  • 惠州 家具 网站上线河南建设网证书查询平台
  • 做个营销型网站设计红酒手机网站模板
  • 2017国办网站建设规范上海虹口网站建设
  • 手机网站关键免费做app网站
  • 费县建设局网站社交网站建站
  • 自己设计手机的网站wordpress主题外贸私人分享
  • 企业网站如何做架构图公司电商网站建设方案模板
  • 个体工商户能做网站吗wordpress comment_author_link
  • 一个备案号可以绑定几个网站wordpress 文章 繁体
  • 如何更改网站域名大连手机网站制作
  • 做外汇应该看哪一家网站在线做logo印章网站
  • 做神马网站优化排seo怎么优化网站排名
  • 团队主页 网站模板wordpress模板 微信
  • 《网站建设方案》阻止网站查到访问者ip
  • 做网站维护需要多少钱制作一个购物网站
  • 哪些网站是专做女性护肤品免费自助开通网站
  • 北京哪个网站最好WordPress图片分享社区
  • 南通建设网站哪家好品牌建设助力高质量发展