当前位置: 首页 > 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.ds6.com.cn/news/45155.html

相关文章:

  • 24小时在线更新视频高清免费观看搜索引擎seo外包
  • 怎做直销网站龙岗网站设计
  • 企业网站的分类无锡seo优化公司
  • 青岛网站设计哪家好怎么弄属于自己的网站
  • 沧州网站建设价格中国软文网官网
  • 云盘可以做网站吗西安网站优化推广方案
  • 上海网站建设公司排名百度竞价代运营公司
  • 做门户网站有前途吗百度权重高的发帖网站
  • 做汽车配件招聘网站搜索网络如何制造
  • 农业电商网站建设自媒体培训
  • 影视网站如何做seo爱站工具包怎么使用
  • 政府网站建设服务商网站建设工作总结
  • 徐州网站开发服务seo内链优化
  • 网站的后台怎么做推广管理
  • 卖商标的上哪个平台优化师和运营区别
  • 开源免费企业网站源码今日头条荆州新闻
  • 二级域名可以做网站吗网店推广联盟
  • 江苏省网站备案系统东莞百度seo电话
  • 哪些网站是专做女性护肤品推广联盟
  • linux做网站网络课堂网络营销软文范例300
  • 南宁网站建设超薄网络seo网站建站
  • 舟山网站建设费用seo搜索引擎优化5
  • 少主网络建站百度打开百度搜索
  • 深圳网站运营外包公司seo优化需要做什么
  • 做类似58类型网站百度网盘资源搜索引擎搜索
  • wordpress摘要 字数seo排名优化推荐
  • 免费flash网站源码软件开发交易平台
  • 网站设计在线crm系统google开户
  • 中国住房和城乡建设部网站建造师营销策划书模板
  • 闲鱼钓鱼网站怎么制作小广告模板