当前位置: 首页 > news >正文

免费建站的平台论坛购物网站开发

免费建站的平台,论坛购物网站开发,自贡公司做网站,大良网站建设服务队列 一、简要认识队列二、队列的封装三、队列的应用1.栈和队列的转换2.全排列3.任务调度4.缓存管理 一、简要认识队列 结构:一种特殊的线性表 入队:在队尾插入一个元素 出队:在队头删除一个元素 特点:先入先出 空队列&#xff1…

队列

  • 一、简要认识队列
  • 二、队列的封装
  • 三、队列的应用
    • 1.栈和队列的转换
    • 2.全排列
    • 3.任务调度
    • 4.缓存管理

一、简要认识队列

结构:一种特殊的线性表
入队:在队尾插入一个元素
出队:在队头删除一个元素
特点:先入先出
空队列:队中没有元素

二、队列的封装

class Queue {items = {}count = 0lowCount = 0dequeue() {if(this.isEmpty()){return undefined}let res = this.items[this.lowCount]delete this.items[this.lowCount]this.lowCount++return res}enqueue(data) {this.items[this.count] = datathis.count++}front() {return this.items[this.lowCount]}isEmpty() {return this.size() === 0}size() {return this.count-this.lowCount}clear() {this.items = {}this.count = 0;this.lowCount = 0}toString() {let str = ""for(let i =this.lowCount;i<this.count;i++){str += `${this.items[i]} `}return str}
}

三、队列的应用

1.栈和队列的转换

在这里插入图片描述

class MyStack {constructor() {this.queue1 = [];this.queue2 = [];}push(x) {// 将元素加入非空队列if (this.queue1.length === 0) {this.queue2.push(x);} else {this.queue1.push(x);}}pop() {if (this.empty()) {throw new Error("Stack is empty!");}// 将非空队列中的元素转移到辅助队列中,直到剩余一个元素const nonEmptyQueue = this.queue1.length === 0 ? this.queue2 : this.queue1;const emptyQueue = this.queue1.length === 0 ? this.queue1 : this.queue2;while (nonEmptyQueue.length > 1) {emptyQueue.push(nonEmptyQueue.shift());}// 取出最后一个元素并返回return nonEmptyQueue.shift();}top() {if (this.empty()) {throw new Error("Stack is empty!");}// 将非空队列中的元素转移到辅助队列中,直到剩余一个元素const nonEmptyQueue = this.queue1.length === 0 ? this.queue2 : this.queue1;const emptyQueue = this.queue1.length === 0 ? this.queue1 : this.queue2;while (nonEmptyQueue.length > 1) {emptyQueue.push(nonEmptyQueue.shift());}// 取出最后一个元素并返回const top = nonEmptyQueue.shift();emptyQueue.push(top);return top;}empty() {return this.queue1.length === 0 && this.queue2.length === 0;}
}

2.全排列

在这里插入图片描述

function permute(nums) {const result = [];const queue = [[]]; // 初始队列中只有一个空数组while (queue.length > 0) {const current = queue.shift(); // 取出队列中的当前排列// 如果当前排列的长度等于原始数组的长度,说明找到了一种排列方式if (current.length === nums.length) {result.push(current);continue;}// 尝试将原始数组中剩余的数字加入到当前排列中for (let i = 0; i < nums.length; i++) {// 如果当前数字已经在排列中,跳过这个数字if (current.includes(nums[i])) {continue;}queue.push([...current, nums[i]]); // 将当前数字加入到排列中并加入队列}}return result;
}

3.任务调度

使用队列来管理需要异步执行的任务,确保它们按照顺序执行。

// 定义一个任务队列
const taskQueue = [];// 添加任务到队列
function enqueueTask(task) {taskQueue.push(task);
}// 执行队列中的任务
function processTasks() {while (taskQueue.length > 0) {const task = taskQueue.shift(); // 从队列头部取出任务task(); // 执行任务}
}// 示例任务
function task1() {console.log('Task 1');
}function task2() {console.log('Task 2');
}function task3() {console.log('Task 3');
}// 添加任务到队列
enqueueTask(task1);
enqueueTask(task2);
enqueueTask(task3);// 执行任务队列
processTasks();

4.缓存管理

使用队列来管理数据的加载和展示,避免同时加载大量数据。

// 定义一个数据缓存队列
const dataQueue = [];// 添加数据到队列
function enqueueData(data) {dataQueue.push(data);
}// 展示队列中的数据
function showData() {while (dataQueue.length > 0) {const data = dataQueue.shift(); // 从队列头部取出数据console.log('Data:', data);}
}// 添加数据到队列
enqueueData('Data 1');
enqueueData('Data 2');
enqueueData('Data 3');// 展示数据队列
showData();
http://www.yayakq.cn/news/221203/

相关文章:

  • 媒体公司网站模板个人博客网页素材
  • 主要的网站开发技术路线360安全浏览器官网入口
  • 网站设计与网页制作岗位招聘信息wordpress 聚合6
  • 企业网站资料大全中国网站开发公司排名
  • 做网站 需要工信部备案吗wordpress comment_reply_link
  • 网站开发建设合同网络服务器
  • 做网站的那些事深圳商业网站建设模板
  • 怎么介绍自己做的网站效果图域名注册人查询
  • 西海岸城市建设局网站做外贸去哪个网站找客户
  • 网站运营维护工作 基本内容包括环球资源外贸网中文版
  • 精简wordpress博客程序seo是什么及作用
  • 江苏建设管理信息网站北京公司黄页大全
  • 响应式网站的几种尺寸教育培训网页设计
  • 贵州建设考试网站网站哪家做的比较好的
  • phpcms网站开发wordpress clean options
  • wordpress进销存插件优化培训方式
  • 做网站用笔记本电脑网站开发设计报告书怎么写
  • 网站平台内容建设提纲鞋帽网站欣赏
  • 做国际网站的上海高端网站公司wordpress 早起文章
  • 郑州网站开发定制外包网络安全管理制度
  • 中小学网站建设怎样做网站优化 关键词
  • 如何在360网页上做公司网站安康网站开发公司价格
  • 申请关闭网站地方网 wordpress
  • 山东春季高考网站建设排版素材网站
  • 宁波网站建设多少钱一年wordpress停止循环
  • 二级网站建设方案模板html5效果网站
  • 在婚纱店做网站优化中国 庆阳
  • 2019做网站需要营业执照吗校园电商平台网站建设
  • 合肥电脑网站建站网站设计结果
  • 做音乐网站是不是侵权WordPress无法取消置顶文章