优先队列(基于无序数组,有序数组,堆)

目录

无序数组:

有序数组:

堆:

分析:

代码:

Entry类:


无序数组:

//基于无序数组实现的优先队列
public class PriorityQueue1 <E extends Priority> implements Queue<E> {//数组类型是priority;Priority[] array;  //E extend Priorityint size;public PriorityQueue1(int capacity){array = new Priority[capacity];size = 0;}@Overridepublic boolean offer(E e) {if(isFull()){return false;}array[size++]=e;return true;}@Overridepublic E poll() {if(isEmpty()){return null;}int max=selectMax();int last=size-1;//交换E e =(E)array[max];remove(max);return (E) e;}private void remove(int index){if(index<size-1){System.arraycopy(array,index+1,array,index,size-1-index);//size-1是最后一个索引}array[--size]=null;}//返回优先级最高的索引值private int selectMax(){int max=0;for(int i=1;i<size;i++){if(array[i].priority()>array[max].priority()){max=i;}}return max;}@Overridepublic E peek() {if(isEmpty()){return null;}int max=selectMax();return (E) array[max];}@Overridepublic boolean isEmpty() {return size==0;}@Overridepublic boolean isFull() {return size==array.length;}
}

有序数组:

//基于有序数组实现优先级队列
public class PriorityQueue2 <E extends Priority> implements Queue<E>{Priority [] array;int size;public PriorityQueue2(int capacity){array = new Priority[capacity];}@Overridepublic boolean offer(E value) {if(isFull()){return false;}insert(value);size++;return true;}//插入排序private void insert(E value){int i=size-1;while(i>=0&&array[i].priority()>value.priority()){array[i+1]=array[i];i--;}array[i+1]=value;}@Overridepublic E poll() {if(isEmpty()){return null;}E e=(E) array[size-1];array[--size]=null;return e;}@Overridepublic E peek() {if(isEmpty()){return null;}return (E) array[size-1];}@Overridepublic boolean isEmpty() {return size==0;}@Overridepublic boolean isFull() {return size==array.length;}
}

堆:

分析:

*
* 大顶堆:父节点的值比左右孩子的值大
* 小顶堆:父节点的值比左右孩子的值小
* 如果从索引0开始
* 节点i的父节点为floor(i-1)/2 前提i>0;  节点i的左子节点为2i+1,右子节点为2i+2  前提i<size
* 如果索引从1开始
* 节点i的父节点为i/2  前提i>1;  节点i的左子节点为2i,右子节点为2i+1  前提i<size
* */

offer:

 1.入堆新元素,加入到数组的末尾(索引位置 child)
* 2.将新元素与父节点比较,如果比父节点大,则交换位置,直到新元素不大于父节点,或者到达根节点

poll:

/*
* 1.交换堆顶和堆尾元素,让尾部元素出队
* 2.从堆顶开始,将父元素与两个孩子较大者交换,
* 直到父元素比两个孩子大,或者到达叶节点
* */

代码:

//大顶堆:优先级最高的为0索引
public class PriorityQueue3 <E extends Priority> implements Queue<E>{Priority [] array;int size;public PriorityQueue3(int capacity){array = new Priority[capacity];}@Overridepublic boolean offer(E value) {if(isFull()){return false;}int child=size++;int parent=(child-1)/2;while((child>0)&&(array[parent].priority()<value.priority())){array[child]=array[parent];child=parent;parent=(child-1)/2;}array[child]=value;return true;}@Overridepublic E poll() {if(isEmpty()){return null;}swap(0,--size);Priority e=array[size];array[size]=null;//堆化down(0);return (E) e;}private void down(int parent) {int left=2*parent+1;int right=2*parent+2;int max=parent;//假设父节点最大if(left<size&&array[left].priority()>array[max].priority()){max=left;}if(right<size&&array[right].priority()>array[max].priority()){max=right;}if(max!=parent){swap(max,parent);down(max);}}//交换private void swap(int i,int j){Priority temp=array[i];array[i]=array[j];array[j]=temp;}@Overridepublic E peek() {if(isEmpty()){return null;}return (E) array[0];}@Overridepublic boolean isEmpty() {return size==0;}@Overridepublic boolean isFull() {return size==array.length;}
}

Entry类:

public class Entry implements Priority{String value;int priority;public Entry(String value, int priority){this.value = value;this.priority = priority;}@Overridepublic int priority() {return priority;}@Overridepublic String toString() {return "(" +"value=" + value + '='+", priority=" + priority +')';}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/885248.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第二话:JS中new操作符的原理

摘要 用最简单易懂的话&#xff0c;解释复杂的问题。 想必各位总是在面试中被面试官问到&#xff1a; 知道JS中new操作符的原理吗&#xff0c;可以简单实现一下吗&#xff1f; 如果你是第一次碰到这种问题&#xff0c;一定满脑子都是问号。new不是操作符吗&#xff1f;我怎么…

粤荣学校与亲邻家政达成合作,创造双向人才输送机制

原标题&#xff1a;超过大学生月薪&#xff01;粤荣学校与亲邻家政达成合作&#xff0c;创造双向人才输送机制&#xff0c;解决中年人就业难题&#xff01; 广州市白云区粤荣职业培训学校余智强校长与广州亲邻家政服务有限公司朱利生经理于2024年11月8日下午共同签署了一份重要…

实现 Nuxt3 预览PDF文件

安装必要的库&#xff0c;这里使用PDF.js库 npm install pdfjs-dist --save 为了解决跨域问题&#xff0c;在server/api 下 创建一个请求api&#xff0c; downloadFileByProxy.ts import { defineEventHandler } from h3;export default defineEventHandler(async event >…

【MacOS实操】如何基于SSH连接远程linux服务器

MacOS上远程连接linux服务器&#xff0c;可以使用ssh命令pem秘钥文件连接。 一、准备pem秘钥文件 如果已经有pem文件&#xff0c;则跳过这一步。如果手上有ppk文件&#xff0c;那么需要先转换为pem文件。 macOS 的默认 SSH 客户端不支持 PPK 格式&#xff0c;你需要将 PPK 文…

SQL server增删改查语句和实例

在 SQL Server 中&#xff0c;增删改查操作分别对应 INSERT、DELETE、UPDATE 和 SELECT 语句。以下是具体介绍及实例&#xff1a; 一、插入数据&#xff08;INSERT&#xff09; 语法&#xff1a; INSERT INTO table_name (column1, column2, column3,...) VALUES (value1, val…

parseInt 是一个内置的 JavaScript 函数,用于将字符串转换为整数。

parseInt(options.checkNumber, 10) 中的 10 表示将字符串转换为十进制整数。 解释 parseInt 函数&#xff1a; parseInt 是一个内置的 JavaScript 函数&#xff0c;用于将字符串转换为整数。它有两个参数&#xff1a; 第一个参数是要转换的字符串。第二个参数是转换时使用的基…

鸿蒙ArkTS中的布局容器组件(Scroll、List、Tabs)

1、Scroll组件 Scroll组件是一个可滚动的容器组件&#xff0c;用于在子组件的布局尺寸超过父组件尺寸时提供滚动功能。它允许在其内部容纳超过自身显示区域的内容&#xff0c;并通过滚动机制来查看全部内容。这对于显示大量信息&#xff08;如长列表、长篇文本或大型图像等&…

ElasticSearch备考 -- Manage the index lifecycle (ILM)

一、题目 在集群中&#xff0c;数据首先分布在data_hot节点&#xff0c;rollover 设置max_age:3d, max_docs:5,max_size:50gb, 优先级为100。 max_age:15s, forcemarge 段合并&#xff0c;数据迁移到data_warm节点&#xff0c; 副本数为0&#xff0c;优先级为50 max_age:30s, 数…

信息安全工程师(81)网络安全测评质量管理与标准

一、网络安全测评质量管理 遵循标准和流程 网络安全测评应严格遵循国家相关标准和流程&#xff0c;确保测评工作的规范性和一致性。这些标准和流程通常包括测评方法、测评步骤、测评指标等&#xff0c;为测评工作提供明确的指导和依据。 选择合格的测评团队 测评团队应具备相关…

使用 Python 构建代理池并测试其有效性

前言 在本篇文章中,我们将介绍如何通过 Python 脚本来构建一个代理池,并且对这些代理的有效性进行测试。整个流程涵盖了从网站抓取代理信息、存储这些信息以及异步地测试代理的有效性。这个脚本可以用作网络爬虫或其他需要使用代理服务器的应用的基础工具。 目标网站 一、…

设计者模式之策略模式

前言 在软件构建过程中&#xff0c;某些对象使用的算法可能多种多样&#xff0c;经常改变&#xff0c;如果将这些算法都写在对象中&#xff0c;将会使对象变得异常复杂&#xff1b;而且有时候支持不频繁使用的算法也是一个性能负担。 如何在运行时根据需要透明地更改对象的算…

tomcat 开启远程debug模式

1.修改位置 CATALINA_OPTS"-Xdebug -Xrunjdwp:transportdt_socket,address*:8000,servery,suspendn"2.修改环境变量的方式 apache-tomcat-9.0.86/bin/setenv.sh export JAVA_HOME/opt/jdk1.8.0_171 export CATALINA_HOME/opt/apache-tomcat-9.0.86 export JAVA_OP…

AI辅助论文写作的利弊

人工智能的时代&#xff0c;AI从自动驾驶到智能家居&#xff0c;慢慢的都成为了我们生活中的一部分。可当AI被放到学术研究领域&#xff0c;特别是撰写论文这一问题上时&#xff0c;却出现了大量的争议&#xff0c;认为AI撰写论文会削弱该有的批判性思维能力。那不用AI撰写论文…

vue3+less使用主题定制(多主题定制)可切换主题

假如要使用两套主题&#xff1a;蓝色、红色 例如&#xff1a; 首先确保自己的vue3项目有less&#xff0c;这边不多做接入解释 1、在src目录下建一个styles文件夹&#xff0c;在syles文件夹下面新建两个less文件&#xff1a;theme.less和variables.less&#xff1b; theme.le…

后端Node学习项目-项目基础搭建

前言 各位好&#xff0c;我是前端SkyRain。最近为了响应公司号召&#xff0c;开始对后端知识的学习&#xff0c;作为纯粹小白&#xff0c;记录下每一步的操作流程。 项目仓库&#xff1a;https://gitee.com/sky-rain-drht/drht-node 因为写了文档&#xff0c;代码里注释不是很…

6-1.Java 面向对象 - 初级(对象与属性、对象与方法、递归、重载、可变参数、作用域、构造器、对象创建流程详解、this 关键字)

一、对象与属性 1、基本介绍 属性是类的一个组成部分&#xff0c;一般是基本数据类型&#xff0c;也可以是引用数据类型 属性的定义语法类似变量 【访问修饰符】 【属性类型】 【属性名】;属性的定义类型可以为任何类型&#xff08;基本数据类型、引用数据类型&#xff09;…

Maven(六)mvn 命令将 jar 包推送到 远程/本地仓库

目录 一、deploy - 推送到远程仓库1.1 命令语法&#xff1a;1.2 执行结果&#xff1a;1.3 可能遇到的问题问题1&#xff1a;with status code 401问题2&#xff1a;with status code 405问题3&#xff1a;Cannot deploy artifact from the local repository 二、install - 推送…

C语言心型代码解析

方法一 心型极坐标方程 爱心代码你真的理解吗 笛卡尔的心型公式&#xff1a; for (y 1.5; y > -1.5; y - 0.1) for (x -1.5; x < 1.5; x 0.05) 代码里面用了二个for循环&#xff0c;第一个代表y轴&#xff0c;第二个代表x轴 二个增加的单位不同&#xff0c;能使得…

JVM 由多个模块组成,每个模块负责特定的功能

Java虚拟机&#xff08;JVM, Java Virtual Machine&#xff09;是一个抽象的计算机&#xff0c;它提供了一个运行环境&#xff0c;使得Java字节码可以在不同的平台上执行。JVM 由多个模块组成&#xff0c;每个模块负责特定的功能。以下是 JVM 的主要模块及其功能&#xff1a; …

Java 中基于优先级执行任务的线程池实现

在日常开发中&#xff0c;我们经常遇到这样一种需求&#xff1a;需要按照任务的优先级顺序来执行&#xff0c;而不是简单的先进先出&#xff08;FIFO&#xff09;。Java 提供了 PriorityBlockingQueue&#xff0c;这是一个基于优先级排序的线程安全队列&#xff0c;可以用于实现…