队列&优先队列
1、队列
普通的队列都是先进先出,元素从队尾添加,从队头删除。
function queue(){
var arr=[];
this.enqueue=function(item){
arr.push(item);
};
this.dequeue=function(){
arr.shift();
};
this.queueSize=function(){
return arr.length;
};
this.isEmpty=function(){
return arr.length==0;
};
this.front=function(){
return arr[0];
};
this.clear=function(){
arr=[];
};
this.print=function(){
console.log(arr.toString());
}
}
var q=new queue();
q.enqueue('1');
q.enqueue(2);
q.enqueue(3);
q.dequeue()
q.print();
2、优先级队列
优先队列中,元素被赋予优先级。当访问元素时,具有最高优先级的元素最先删除。优先队列具有最高级先出的特征。
| 任务编号 | 1 | 2 | 3 | 4 | 5 |
| 优先级编号 | 20 | 0 | 40 | 30 | 10 |
| 执行顺序 | 3 | 1 | 5 | 4 | 2 |
优先号越小,优先级越高。
优先队列主要有3个操作,查找,插入,删除。
分为两种最大优先队列和最小优先队列。
最大优先队列:先查找,找到优先级最大的元素将其删除。
最小优先队列:先查找,找到优先级最小的元素将其删除。
下面用JS写一个最大优先队列。入队列我们按照优先级从小到大排序,出队列仍然直接从队首出
function priorityQueue(){
var arr=[];
this.enqueue=function(item,pri){ // 入队列要比较优先级大小。同等优先级的情况下,按照普通队列处理
var flag=false;
var temp={
item:item,
pri:pri
}
for(var i=0,len=arr.length;i<len;i++){
if(arr[i].pri>temp.pri){
arr.splice(i,0,temp);
flag=true;
break;
}
}
if(flag==false){
arr.push(temp);
}
};
this.dequeue=function(){
arr.shift();
};
this.size=function(){
return arr.length;
};
this.isEmpty=function(){
return arr.length==0;
};
this.front=function(){
return arr[0];
};
this.clear=function(){
arr=[];
};
this.print=function(){
for(var i=0;i<arr.length;i++){
console.log(arr[i].item);
}
}
}
var q=new priorityQueue();
q.enqueue(1,30);
q.enqueue(2,20);
q.enqueue(3,90);
q.enqueue(4,0);
q.enqueue(5,50);
q.enqueue(7,30);
q.enqueue(8,0);
q.dequeue();
q.print();
队列&优先队列的更多相关文章
- luogu 2827 蚯蚓 单调队列/优先队列
易知可利用优先队列选取最大值: 但是通过分析可知,先取出的蚯蚓分开后仍然要比后分的长,所以可直接利用单调队列找队头即可,分三个单调队列,分别找未切割,切割,切割2三种情况 #include<bi ...
- Java栈,队列,优先队列的使用
1. 栈的使用: import java.util.*; public class Main{ public static void main(String[] args){ Deque<Str ...
- 【STL】栈+队列+优先队列(详)+ 拯救行动题解
一.栈 栈(stack)又名堆栈,它是一种运算受限的线性表.其限制是仅允许在表的一端进行插入和删除运算.这一端被称为栈顶,相对地,把另一端称为栈底.向一个栈插入新元素又称作进栈.入栈或压栈,它是把新元 ...
- Windows消息队列(优先队列,结构体中放比较函数)
Windows消息队列 消息队列是Windows系统的基础.对于每个进程,系统维护一个消息队列.如果在进程中有特定事件发生,如点击鼠标.文字改变等,系统将把这个消息加到队列当中.同时,如果队列不是空的 ...
- 【UVA】12100 Printer Queue(STL队列&优先队列)
题目 题目 分析 练习STL 代码 #include <bits/stdc++.h> using namespace std; int main() { int t; sc ...
- STL 优先队列
STL 栈,队列,优先队列用法 分类: Learning C++2013-11-15 00:52 843人阅读 评论(2) 收藏 举报 c++栈队列优先队列STL STL 中栈的使用方法(stack) ...
- 数据结构——队列(Queues)
队列的存储特性:FIFO(first in first out)即先进先出原则 单向/双向队列 *优先队列(与queue不同) 存储方式: 带尾指针的单向链表 / 数组 queue类: queue() ...
- JavaScript数据结构与算法(三) 优先级队列的实现
TypeScript方式实现源码 // Queue类和PriorityQueue类实现上的区别是,要向PriorityQueue添加元素,需要创建一个特殊的元素.这个元素包含了要添加到队列的元素(它可 ...
- 数据结构与算法——优先队列类的C++实现(二叉堆)
优先队列简单介绍: 操作系统表明上看着是支持多个应用程序同一时候执行.其实是每一个时刻仅仅能有一个进程执行,操作系统会调度不同的进程去执行. 每一个进程都仅仅能执行一个固定的时间,当超过了该时间.操作 ...
随机推荐
- Python 数据文件操作——写出数据
- 洛谷P2982 [USACO10FEB]慢下来Slowing down [2017年四月计划 树状数组01]
P2982 [USACO10FEB]慢下来Slowing down 题目描述 Every day each of Farmer John's N (1 <= N <= 100,000) c ...
- Leetcode49. Group Anagrams字母异位词分组
给定一个字符串数组,将字母异位词组合在一起.字母异位词指字母相同,但排列不同的字符串. 示例: 输入: ["eat", "tea", "tan&quo ...
- jquery Select2 学习笔记之中文提示 - CSDN博客
首先学习这个东西呢,还是看官网比较全面 select2官网例子 要select2中文显示:必须要引入中文包,且一定要放在select2.js之后 [javascript] view plain cop ...
- 解决安装编译工具gcc后无法连接mysql
在安装编译工具gcc后: yum -y install make gcc g++ gcc-c++ libtool autoconf automake imake mysql-devel libxml2 ...
- OpenLayers使用点要素作为标记
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head ...
- HTML 实体字符
有些字符,像(<)这类的,对HTML来说是有特殊意义的,所以这些字符是不允许在文本中使用的.要在HTML中显示(<)这个字符,我们就必须使用实体字符. 实体字符 有一些字符对HTML来讲是 ...
- Python3.7.4入门-6/7错误和异常/类
6 错误和异常 while True: try: x = int(input("Please enter a number: ")) break except ValueError ...
- vue项目开发过程常见问题
更新时间:2018-07-29 1.data functions should return an object // 这个问题是 Vue 实例内,单组件的data必须返回一个对象;如下 <sc ...
- iOS开发——你真的会用SDWebImage?
http://www.cocoachina.com/ios/20160503/16064.html 本文授权转载,作者:hosea_zhou(简书) SDWebImage作为目前最受欢迎的图片下载第三 ...