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

网站的建立设计app的软件

网站的建立,设计app的软件,黑客怎么入侵网站,网站标签制作文章目录优先级队列模拟实现优先级队列向下调整建堆向上调整建堆堆的删除priorityQueue构造方法大根堆和小根堆的向上调整比较方法扩容面试题堆排序优先级队列 priorityqueue:底层是一颗完全二叉树 小根堆:根比左右孩子都小大根堆:根比左右…

文章目录

  • 优先级队列
  • 模拟实现优先级队列
    • 向下调整建堆
    • 向上调整建堆
    • 堆的删除
  • priorityQueue
    • 构造方法
    • 大根堆和小根堆的向上调整比较方法
    • 扩容
  • 面试题
  • 堆排序

优先级队列

priorityqueue:底层是一颗完全二叉树

  1. 小根堆:根比左右孩子都小
  2. 大根堆:根比左右孩子都大
  3. 用数组存储

在这里插入图片描述

模拟实现优先级队列

向下调整建堆

  1. 向下调整算法的时间复杂度:O(N)
    建堆的算法

在这里插入图片描述
2. 推导过程:

在这里插入图片描述

	// 向下调整算法public void shifDown(int parent,int len){// parent每次从根节点开始向下调整// usedSize来检测是否还有得调,是否调结束了int child = 2 * parent + 1;// 至少有右孩子while(child < len){// 左右孩子比较大小,如果右孩子大,那么child+1if(child + 1 < len && elem[child] < elem[child + 1]){child = child + 1;}// if语句走完,证明child是左右孩子中大的那个的下标if(elem[child] > elem[parent]){int tmp = elem[child];elem[child] = elem[parent];elem[parent] = tmp;parent = child;child = parent * 2 + 1;}else{// 证明左右孩子中最大的那个都比父亲节点小,// 是大根堆,不用调整了break;}}}

向上调整建堆

  1. 新插入一个节点并且向上调整为大根堆
  2. 向上调整建堆的时间复杂度是:O(N * logN)

在这里插入图片描述

 // 插入一个节点向上调整算法public void push(int val){// 满了,扩容if(isFull()){elem = Arrays.copyOf(elem,2 * elem.length);}elem[usedSize] = val;// 向上调整,usedSize为新插入元素的下标siftUp(usedSize);usedSize++;}public void swap(int i,int j){int tmp = elem[i];elem[i] = elem[j];elem[j] = tmp;}public boolean isFull(){return usedSize == elem.length;}public void siftUp(int child){// 通过孩子节点找到父亲节点下标// 只要child大于0还需要调整,=0就不需要调整了while(child > 0) {int parent = (child - 1) / 2;if (elem[parent] < elem[child]) {swap(child, parent);child = parent;parent = (child - 1) / 2;} else {// parent下标对应的元素大于child下标对应的元素// 不需要交换break;}}}

堆的删除

  1. 让堆顶元素和最后一个元素交换
  2. 然后让usedSize–,就删除了最后一个元素
  3. 最后只需要调整0下标这棵树就行了,使用向下调整算法
public int pop(){// 判空if(empty()){return -1;}int tmp = elem[0];swap(0,usedSize - 1);usedSize--;shifDown(0,usedSize);return tmp;}public boolean  empty(){return usedSize == 0;}

priorityQueue

  1. Java中的优先级队列默认是小根堆
public static void main(String[] args) {// 默认是小根堆PriorityQueue<Integer> priorityQueue = new PriorityQueue<>();priorityQueue.offer(1);priorityQueue.offer(5);priorityQueue.offer(6);System.out.println(priorityQueue.poll());// 1System.out.println(priorityQueue.poll());// 5}
  1. PriorityQueue必须存放可以比较大小的元素
  2. 不能插入null对象,否则会抛出空指针异常
  3. 没有容量限制,可以插入任意多个元素,其内部可以自动扩容,在堆上开空间的
  4. 插入和删除的时间复杂度都是O(logN)

构造方法

在这里插入图片描述

大根堆和小根堆的向上调整比较方法

  1. 插入元素,向上调整,向上调整的比较方法
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

扩容

  1. 要么2倍扩容,要么1.5倍扩容
    在这里插入图片描述

面试题

  1. top-k问题:
    解法一:
    比如得到最小的前k个元素
    建立一个小根堆
    出k次元素得到最小的前k个元素

解法二:
求最小的前k个元素,先把前k个元素建立大根堆,再和k+1位置的元素比较,如果小于堆顶元素就入堆,并且删除堆顶元素,以此类推,最后剩下的k个元素就是最小的元素
在这里插入图片描述
3. top-k问题的时间复杂度是:O(N * logK)
求最小的K个数

// class Imp implements Comparator<Integer> {
//     public int compare(Integer o1,Integer o2){
//         return o2.compareTo(o1);
//     }
// }class Solution {public int[] smallestK(int[] arr, int k) {int[] ret = new int[k];if(arr == null || k <= 0){return ret;}// new一个比较器,匿名内部类的方法PriorityQueue<Integer> priorityQueue = new PriorityQueue<>(new Comparator<Integer>(){public int compare(Integer o1,Integer o2){return o2.compareTo(o1);}});// 建立k个元素的大根堆// K * logKfor(int i = 0;i < k;i++){priorityQueue.offer(arr[i]);}// O((N-k) * logK)for(int i = k;i < arr.length;i++){int top = priorityQueue.peek();if(top > arr[i]){priorityQueue.poll();priorityQueue.offer(arr[i]);}}// 总的时间复杂度: O(N * logK)// K * logK// 整理元素不算入top-k问题中for(int i = 0;i < k;i++){ret[i] = priorityQueue.poll();}return ret;}
}

堆排序

  1. 从大到小或者是从小到大排序
  2. 从小到大排序,建立大根堆,每次最后一个元素和堆顶元素交换,usedSize–,向下调整为大根堆,以此类推
  3. 堆排序的时间复杂度:O(N * logN)

在这里插入图片描述

// 堆排序public void heapSort(){int end = usedSize - 1;while(end > 0){swap(0,end);shifDown(0,end);end--;}}public static void main(String[] args) {TestHeap testHeap = new TestHeap();int array[] = {27,15,19,18,28,34,65,49,25,37};testHeap.initElem(array);// 向下调整建堆:O(N)testHeap.createHeap();System.out.println("======");// O(N * logN)testHeap.heapSort();System.out.println("======");}
http://www.dtcms.com/a/420184.html

相关文章:

  • “优化编码(Z)” 带来更稳定?还是带来不稳定?- Task.Delay引发的思考
  • 医疗网站前置审批广州制作网站公司简介
  • 帮人做钓鱼网站以及维护建设工程招标专业网站
  • 河南基安建设集团有限公司网站江苏常州网站建设
  • 小视频网站源码不良网站进入窗口
  • 分割数组得到最小绝对差
  • openGauss数据库自动安装脚本
  • GSM8K:评估大模型数学推理能力的关键数据集
  • 网站建立公司百度站长平台h5网站
  • P1989 三元环计数
  • asp 公司网站建设网站培训班
  • 郴州网站制作公司电话网站下拉广告
  • 营销型网站建设的概念WordPress网站封装app教程
  • 天津建设厅网站导航网站怎么赚钱
  • 做带支付功能的网站网站和软件建站
  • 广西桂林建设局网站手游排行榜
  • 【QT第二章】信号与槽
  • 网站建设站点做网站通过什么赚钱
  • 济宁网站建设是什么意思wordpress头像上传插件
  • 做影视网站什么cms好用吗网站配置域名这样做
  • 【Spring】Spring Boot 自动配置
  • 青浦网站优化前程无忧做网站多少钱
  • 常熟港口建设费申报网站怎么网站建设
  • 文件的读写 二进制形式打开文件
  • 吴忠住房和城乡建设网站成都官网seo技术
  • 惠州建网站服务天津专业网站制作流程优势
  • 北京联通网站备案php 网站模板
  • 清河做网站哪里好齐河网站建设
  • CodeBuddy CLI工具深度测评:从零到一实现鸿蒙游戏开发实践
  • 网站前后台模板服务专业的网站建设服务