javascript实现优先队列

/*--------------Queue类的定义和测试代码----------------*/
function Queue(){
        this.dataStore = [];
        this.enqueue = enqueue;
        this.dequeue = dequeue;
        this.front = front;
        this.back = back;
        this.toString = toString;
        this.empty = empty;
}

//入队,就是在数组的末尾添加一个元素
function enqueue(element){
    this.dataStore.push(element);
}
//出队,判断优先级删除,注意这里用的是数组的splice方法,不是slice方法
function dequeue(){
    var priority = this.dataStore[0].code;
    var fromIndex = 0;
    for (var i=1; i<this.dataStore.length; ++i) {
        if (this.dataStore[i].code < priority) {
            fromIndex = i;
        }
    }
    return this.dataStore.splice(fromIndex, 1);
}
//取出数组的第一个元素
function front(){
    return this.dataStore[0];
}
//取出数组的最后一个元素
function back(){
    return this.dataStore[this.dataStore.length-1];
}

function toString(){
    var retStr = "";
    for (var i=0; i<this.dataStore.length; ++i) {
        retStr += "病人:" + this.dataStore[i].name + " 优先级:" + this.dataStore[i].code + "<br>"
    }
    return retStr;
}
//判断数组是否为空
function empty(){
    if(this.dataStore.length == 0){
        return true;
    }else{
        return false;
    }
}
//返回数组中元素的个数
function count(){
    return this.dataStore.length;
}

/*----------------基数排序-----------------*/

function Patient(name, code){
    this.name = name;
    this.code = code;
}
var p = new Patient(‘smith‘, 5);
var ed = new Queue();
ed.enqueue(p);

p = new Patient(‘jones‘, 4);
ed.enqueue(p);

p = new Patient(‘fehrendbach‘, 6);
ed.enqueue(p);

p = new Patient(‘brown‘, 1);
ed.enqueue(p);

p = new Patient(‘ingram‘, 1);
ed.enqueue(p);

document.write(ed.toString());

var seen = ed.dequeue();
document.write(‘<br>‘);
document.write("服务病人:" + seen[0].name);

document.write(‘<br>‘);
document.write(ed.toString());

seen = ed.dequeue();
document.write(‘<br>‘);
document.write("服务病人:" + seen[0].name);

document.write(‘<br>‘);
document.write(ed.toString());

seen = ed.dequeue();
document.write(‘<br>‘);
document.write("服务病人:" + seen[0].name);

document.write(‘<br>‘);
document.write(ed.toString());

输出结果为:

时间: 2024-08-07 21:20:08

javascript实现优先队列的相关文章

javascript数据结构-优先队列

这里之所以扩充一个 有限队列 是因为,生活使用中队列通常会附加优先级,比如排队买票,一般老人和军人等会有优先权限. 实现:继承上篇的 普通队列实现.这里用一种方法,入队的时候,进行排序插入到指定位置,输出不变. 优先队列类 //继承自 Queue function PriorityQueue(){ Queue.call(this); } 继承原型方法 function base(p, c){ var h = {}, P = p.prototype, C = c.prototype; for(va

javascript的队列,优先队列,循环队列

按书上的来弄的.慢慢理解了. function Queue() { var items = []; this.enqueue = function(element){ items.push(element); } this.dequeue = function(){ return items.shift(); } this.front = function(){ return items[0]; } this.isEmpty = function(){ return items.length =

第五章:javascript:队列

队列是一种列表,不同的是队列只能在末尾插入元素,在队首删除元素.队列用于存储俺顺序排列的数据.先进先出.这点和栈不一样,在栈中,最后入栈的元素反被优先处理.可以将队列想象成银行排队办理业务的人,排队在第一个的人先办理业务,其它人只能排着,直到轮到他们为止. 队列是一种先进先出(FIFO)的数据结构.队列被用在很多地方.比如提交操作系统执行一系列进程.打印任务池等.一些仿真系统用来模拟银行或杂货店里排队的顾客. 一,队列的操作. 队列的两种主要操作是:向队列中插入新元素和删除队列中的元素.插入操作

javascript数据结构与算法---队列

队列是一种列表,不同的是队列只能在队尾插入元素,在队首删除元素.队列用于存储按顺序排列的数据,先进先出,这点和栈不一样(后入先出).在栈中,最后入栈的元素反而被优先处理.我们现在可以把队列想象对我们去餐馆吃饭的情景,很多人排队吃饭,排在最前面的人先打饭.新来的人只能在后面排队.直到轮到他们为止. 一:对队列的操作 队列有2种主要的操作,向队尾中插入新元素enqueue()方法和删除队列中的队首的元素的dequeue()方法,另外我们还有一个读取队头的元素,这个方法我们可以叫front()方法.该

Javascript用数组实现栈和队列

栈是遵循后进先出(LIFO)规则的一种有序集合,比如桌上的一叠书,我们只能从上面放或取. 队列是遵循先进先出(FIFO)规则的一种有序集合,比如排队,先排到的先离开. 数组也是一种有序的集合,它与上面两种数据结构类似.由于JavaScript中的数组本身拥有许多简单的方法,如push(), 所以用数组来表示栈和队列非常简单. 首先回顾一下相关的方法: push():向数组尾部添加一个或多个项. pop():删除数组尾部的一个项. unshift():先数组头部添加一个或多个项. shift():

javascript常用经典算法实例详解

javascript常用经典算法实例详解 这篇文章主要介绍了javascript常用算法,结合实例形式较为详细的分析总结了JavaScript中常见的各种排序算法以及堆.栈.链表等数据结构的相关实现与使用技巧,需要的朋友可以参考下 本文实例讲述了javascript常用算法.分享给大家供大家参考,具体如下: 入门级算法-线性查找-时间复杂度O(n)--相当于算法界中的HelloWorld ? 1 2 3 4 5 6 7 8 9 10 //线性搜索(入门HelloWorld) //A为数组,x为要

《数据结构与算法JavaScript描述》

<数据结构与算法JavaScript描述> 基本信息 作者: (美)Michael McMillan 译者: 王群锋 杜欢 丛书名: 图灵程序设计丛书 出版社:人民邮电出版社 ISBN:9787115363398 上架时间:2014-8-5 出版日期:2014 年8月 开本:16开 版次:1-1 所属分类:计算机 > 软件与程序设计 > 网络编程 > javascript 更多关于>>> <数据结构与算法JavaScript描述> 编辑推荐 随着

javascript数据结构——队列

队列是一种先进先出的数据结.队列只能在队尾插入元素,在队首删除元素,这点和栈不一样.它用于存储顺序排列的数据.队列就像我们日常中的排队一样,排在最前面的第一个办理业务,新来的人只能在后面排队.队列这种数据结构在编程中被用到很多地方. 定义队列的操作 上图展示了队列的两个操作,入队和出队.出队操作是删除对头的元素,入队操作是在队尾添加元素.除此之外我们还需要能够获取队首和队尾的元素或者全队列的元素,还需要知道队列的长度,还需要一个方法来清空队列,由此,我们定义队列的方法. enqueue()   

JavaScript 的数据结构与算法

1数组 1.1方法列表 数组的常用方法如下: concat: 链接两个或者更多数据,并返回结果. every: 对数组中的每一项运行给定的函数,如果该函数对每一项都返回true,则返回true. filter: 对数组中的每一项运行给定函数,返回改函数会返回true的项组成的数组. forEach: 对数组中的每一项运行给定函数,这个方法没有返回值. join: 将所有的数组元素链接成一个字符串. indexOf: 返回第一个与给定参数相等的数组元素的索引,没有找到则返回-1. lastInde