百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

前端如何实现队列

liuian 2025-04-29 02:06 7 浏览

前言

队列对于我们来说再简单不过了,就是排队呀,咱们今天看看怎么使用js 实现队列的思想,简单容易理解,可以看看偶

1.定义

队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列 先进先出

2.队列的实现

2.1 对列的方法

  1. enqueue 从队列尾部添加一个元素
  2. dequeue 从队列头部删除一个元素
  3. head 返回头部的元素 不是删除
  4. size 返回队列的大小
  5. clear 清空队列
  6. isEmpty 判断队列是否为空
  7. tail 返回队列尾节点

2.2 实现一个队列

上次在栈的时候我们使用函数创建对象,这次用es6 的class 来实现

class Queue{  
  constructor(){  
      this.items = [] 
   }    
// 向队列尾部添加一个元素  
  enqueue(item) {  
      this.items.push(item)
    }    
// 移除队列头部的元素  
  dequeue(){     
   return this.items.shift()  
  }    
// 返回队列头部的元素  
  head(){     
   return this.items[0] 
   }       
 // 返回队列尾部的元素  
  tail(){      
  return this.items[this.items.length-1]; 
   }    
 // 返回队列大小    
size(){       
 return this.items.length  
  }    // clear  
  clear(){   
     this.items=[]  
  } 
// isEmpty 判断是否为空队列   
 isEmpty(){      
  return this.items.length === 0 
   }}
let queue = new Queue()queue.enqueue(111)queue.enqueue(222)
exports.Queue = Queue;
console.log(queue.tail())
console.log(queue.head())
console.log(queue.size())
复制代码

3. 队列的应用

3.1 存在一个数组 a[100]存放0-99,要求每隔两个数删除掉一个数,到末尾时候循环至开头继续进行,求最后一个被删掉的数。

3.2 思路

1. 从队列头部删除一个元素, index+1

2. 如果index%3 ===0 就说明这个元素是需要删除的元素,如果不等于0,就不是需要被删除的元素,则把它添加到队列的尾部

不停地有元素被删除,最终队列里只有一个元素,此时while 循环终止,队列的所剩的元素就是最后一个被删除的元素

function del_ring(arr_list){ 
   // 把数组里的元素都放入到队列中
    var queue = new Queue.Queue();  
  for(var i=0;i< arr_list.length;i++){ 
       queue.enqueue(arr_list[i]);  
  }  
  var index = 0;  
  while(queue.size() != 1){       
// 弹出一个元素,判断是否需要删除  
      var item = queue.dequeue();  
      index += 1;       
 // 每隔两个就要删除掉一个,那么不是被删除的元素就放回到队列尾部   
     if(index %3 != 0){      
      queue.enqueue(item);     
   }   
 }    
return queue.head();};
var arr_list = [];
for(var i=0;i< 100;i++){  
  arr_list.push(i);
}
console.log(del_ring(arr_list));
复制代码

3.3 用队列输出杨辉三角的前n行 n >= 1

Queue = require('./myqueue')
function print_yanghui(n){   
 var queue = new Queue.Queue();  
  queue.enqueue(1);  
  // 第一层for循环控制打印几层 
  for(var i=1; i<=n; i++){   
   var line = "";       
   var pre = 0;        
// 第二层for循环控制打印第 i 层 
  for(var j=0; j<i; j++){      
    var item = queue.dequeue();   
    line += item + "  "         
   // 计算下一行的内容         
   var value = item + pre;       
   pre = item;         
   queue.enqueue(value);    
    }       
 // 每一层最后一个数字是1,上面的for循环没有计算最后一个数   
     queue.enqueue(1);   
     console.log(line);   
 }
};
function print_yanghui_2(n){ 
  var queue = new Queue.Queue(); 
   queue.enqueue(1);  
   queue.enqueue(0); 
   for(var i=1; i<=n; i++){   
     var line = "";      
     var pre = 0;     
     while(true){   
     var item = queue.dequeue();    
        // 用一个0把每一行的数据分割开,遇到0不输出,     
     if(item==0){          
       queue.enqueue(1);     
           queue.enqueue(0);  
             break        
    }else {      
        
  // 计算下一行的内容          
   line += item + "  "     
          
    var value = item + pre;    
        pre = item;       
        queue.enqueue(value);   
      }     
   }     
   console.log(line);  
  }
}
print_yanghui(10);
//print_yanghui_2(10);

总结:

小编是一枚前端程序员,欧而会写一些前端的东西,希望能帮助你偶,大家一起学习,一起进步,加油!

相关推荐

深入解析 MySQL 8.0 JSON 相关函数:解锁数据存储的无限可能

引言在现代应用程序中,数据的存储和处理变得愈发复杂多样。MySQL8.0引入了丰富的JSON相关函数,为我们提供了更灵活的数据存储和检索方式。本文将深入探讨MySQL8.0中的JSON...

MySQL的Json类型个人用法详解(mysql json类型对应java什么类型)

前言虽然MySQL很早就添加了Json类型,但是在业务开发过程中还是很少设计带这种类型的表。少不代表没有,当真正要对Json类型进行特定查询,修改,插入和优化等操作时,却感觉一下子想不起那些函数怎么使...

MySQL的json查询之json_array(mysql json_search)

json_array顾名思义就是创建一个数组,实际的用法,我目前没有想到很好的使用场景。使用官方的例子说明一下吧。例一selectjson_array(1,2,3,4);json_array虽然单独...

头条创作挑战赛#一、LSTM 原理 长短期记忆网络

#头条创作挑战赛#一、LSTM原理长短期记忆网络(LongShort-TermMemory,LSTM)是一种特殊类型的循环神经网络(RNN),旨在解决传统RNN在处理长序列数据时面临的梯度...

TensorBoard最全使用教程:看这篇就够了

机器学习通常涉及在训练期间可视化和度量模型的性能。有许多工具可用于此任务。在本文中,我们将重点介绍TensorFlow的开源工具套件,称为TensorBoard,虽然他是TensorFlow...

图神经网络版本的Kolmogorov Arnold(KAN)代码实现和效果对比

本文约4600字,建议阅读10分钟本文介绍了图神经网络版本的对比。KolmogorovArnoldNetworks(KAN)最近作为MLP的替代而流行起来,KANs使用Kolmogorov-Ar...

kornia,一个实用的 Python 库!(python kkb_tools)

大家好,今天为大家分享一个实用的Python库-kornia。Github地址:https://github.com/kornia/kornia/Kornia是一个基于PyTorch的开源计算...

图像分割掩码标注转YOLO多边形标注

Ultralytics团队付出了巨大的努力,使创建自定义YOLO模型变得非常容易。但是,处理大型数据集仍然很痛苦。训练yolo分割模型需要数据集具有其特定格式,这可能与你从大型数据集中获得的...

[python] 向量检索库Faiss使用指北

Faiss是一个由facebook开发以用于高效相似性搜索和密集向量聚类的库。它能够在任意大小的向量集中进行搜索。它还包含用于评估和参数调整的支持代码。Faiss是用C++编写的,带有Python的完...

如何把未量化的 70B 大模型加载到笔记本电脑上运行?

并行运行70B大模型我们已经看到,量化已经成为在低端GPU(比如Colab、Kaggle等)上加载大型语言模型(LLMs)的最常见方法了,但这会降低准确性并增加幻觉现象。那如果你和你的朋友们...

ncnn+PPYOLOv2首次结合!全网最详细代码解读来了

编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...

人工智能——图像识别(人工智能图像识别流程)

概述图像识别(ImageRecognition)是计算机视觉的核心任务之一,旨在通过算法让计算机理解图像内容,包括分类(识别物体类别)、检测(定位并识别多个物体)、分割(像素级识别)等,常见的应用场...

PyTorch 深度学习实战(15):Twin Delayed DDPG (TD3) 算法

在上一篇文章中,我们介绍了DeepDeterministicPolicyGradient(DDPG)算法,并使用它解决了Pendulum问题。本文将深入探讨TwinDelayed...

大模型中常用的注意力机制GQA详解以及Pytorch代码实现

分组查询注意力(GroupedQueryAttention)是一种在大型语言模型中的多查询注意力(MQA)和多头注意力(MHA)之间进行插值的方法,它的目标是在保持MQA速度的同时...

pytorch如何快速创建具有特殊意思的tensor张量?

专栏推荐正文我们通过值可以看到torch.empty并没有进行初始化创建tensor并进行随机初始化操作,常用rand/rand_like,randint正态分布(0,1)指定正态分布的均值还有方差i...