JavaScript如何实现优先队列与循环队列
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,这篇文章主要介绍了JavaScript如何实现优先队列与循环队列的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript如何实现优先队列与循环队列文章都会有所收
千家信息网最后更新 2025年12月01日JavaScript如何实现优先队列与循环队列
这篇文章主要介绍了JavaScript如何实现优先队列与循环队列的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript如何实现优先队列与循环队列文章都会有所收获,下面我们一起来看看吧。
优先队列
实现一个优先队列:设置优先级,然后在正确的位置添加元素。
我们这里实现的是最小优先队列,优先级的值小(优先级高)的元素被放置在队列前面。
//创建一个类来表示优先队列function Priorityqueue(){ var items=[];//保存队列里的元素 function QueueEle(e,p){//元素节点,有两个属性 this.element=e;//值 this.priority=p;//优先级 } this.enqueue=function(e,p){//添加一个元素到队列尾部 var queueEle=new QueueEle(e,p); var added=false; //priority小的优先级高,优先级高的在队头 if(this.isEmpty()){ items.push(queueEle); }else{ for(var i=0;iqueueEle.priority){ items.splice(i,0,queueEle); added=true; break; } } if(!added){ items.push(queueEle); } } } this.isEmpty=function(){ return items.length==0; } this.dequeue=function(){ return items.shift(); } this.clear=function(){ items=[]; } this.print=function(){ console.log(items); } this.mylength=function(){ return items.length; }}var pqueue=new Priorityqueue();pqueue.enqueue('a',2);pqueue.enqueue('b',1);pqueue.enqueue('c',2);pqueue.enqueue('d',2);pqueue.enqueue('e',1);pqueue.print();//[ QueueEle { element: 'b', priority: 1 },// QueueEle { element: 'e', priority: 1 },// QueueEle { element: 'a', priority: 2 },// QueueEle { element: 'c', priority: 2 },// QueueEle { element: 'd', priority: 2 } ] 运行结果:
在正确的位置添加元素:如果队列为空,可以直接将元素入列。否则,就需要比较该元素与其他元素的优先级。当找到一个比要添加的元素优先级更低的项时,就把新元素插入到它之前,这样,对于其他优先级相同,但是先添加到队列的元素,我们同样遵循先进先出的原则。
最大优先队列:优先级的值大的元素放置在队列前面。
循环队列
实现击鼓传花游戏。
//创建一个类来表示队列function Queue(){ var items=[];//保存队列里的元素 this.enqueue=function(e){//添加一个元素到队列尾部 items.push(e); } this.dequeue=function(){//移除队列的第一项,并返回 return items.shift(); } this.front=function(){//返回队列的第一项 return items[0]; } this.isEmpty=function(){//如果队列中部包含任何元素,返回true,否则返回false return items.length==0; } this.mylength=function(){//返回队列包含的元素个数 return items.length; } this.clear=function(){//清除队列中的元素 items=[]; } this.print=function(){//打印队列中的元素 console.log(items); }}//击鼓传花function hotPotato(namelist,num){ var queue=new Queue(); for(var i=0;i1){ for(i=0;i运行结果:
得到一份名单,把里面的名字全都加入队列。给定一个数字,然后迭代队列。从队列头移除一项,加入到队列尾部,模拟循环队列。一旦传递次数达到给定的数字,拿到花的那个人就被淘汰。最后只剩一个人的时候,他就是胜利者。
关于"JavaScript如何实现优先队列与循环队列"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"JavaScript如何实现优先队列与循环队列"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。
队列
元素
优先级
循环
尾部
知识
位置
内容
数字
篇文章
结果
传花
运行
最小
相同
两个
个人
个数
价值
先进
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全模型中 什么是基石
学校秋天网络安全会议
正泰网络技术 氛围
联想服务器登录密码忘记如何找回
工信部 网络安全中心
机关网络安全管理责任制度
计算机网络技术与应用第五章
教务处数据库改成绩
文明重启如何加入同一个服务器
产品序列号数据库
软件开发的心路历程
未来科技城和互联网小镇
银信科技 工业互联网
本溪服务器维保
电力成果数据库
丹江口软件开发
超赢收银系统的数据库怎么安装
数据库系统与应用习题
程序员对数据库要求
河北现代化软件开发批发
服务器咋看地图种子
ibmx440服务器管理口
济南网络安全座谈会
三一软件开发
政法委个人网络安全保密协议
疫情期间网络安全保障网络教学
安卓 数据库空指针
河北戴尔服务器续保哪家便宜
php数据库自学教程交流
软件开发不好学