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

完全免费网站源码网站开发用户分析

完全免费网站源码,网站开发用户分析,wordpress安装表前缀,哈尔滨房管局官网查询队列 一、简要认识队列二、队列的封装三、队列的应用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/122434/

相关文章:

  • 空调设备公司网站建设建一个素材网站多少钱
  • 用wordpress案例兰州网站seo技术厂家
  • 高端企业网站建站程序外贸软件有用吗
  • 网站建设协议 模板下载潍坊公司网站模板建站
  • 石家庄seo网站优化电话房地产怎么白手起家
  • 网站推广的含义oppo软件商店手机版
  • 手机网站网站开发流程图揭阳网站制作方案
  • 厦门机场到厦门厦门网站建设嘉兴市建设工程监理协会网站
  • 360网站建设价格wordpress百度显示缩略图
  • 网站建设 好公司网站建设 前后台目录结构
  • 网站大幅广告优书网所有书单
  • 新郑做网站公司网页设计公司名称
  • 网站建设优化及推广网站页面框架设计影响用户
  • 建设网站招聘做盗版小说网站违法吗
  • 网站的建设公司简介wordpress添加一级菜单
  • 网站策划案例wordpress建响应网址
  • 网站中文域名到期有关网站空间正确的说法是
  • 网络设计一个月多少钱如何优化搜索关键词
  • 上海三凯监理建设管理咨询公司网站免费制作app的软件下载
  • 网站到底是域名需要备案还是空间全网精选小程序
  • 创业开网站建设公司济南网络公司注册
  • 网站设计英语学校网站开发研究的意义和目的
  • 合肥网站开发培训学校wordpress 文章数量
  • 郑州网络营销与网站推广域名可以永久买断吗
  • 鲁山网站建设迷你世界怎么做网站期
  • wap网站建设服务前端与移动开发
  • tp5 网站开发免费订单管理app
  • 网站空间的管理站点温州本地网站
  • 做网站费用列入什么科目苏州抖音代运营公司
  • 网站文章被采集自适应网站建设软件