博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript数据结构与算法-队列练习
阅读量:4960 次
发布时间:2019-06-12

本文共 3234 字,大约阅读时间需要 10 分钟。

队列的实现

// 队列类function Deque () {    this.dataStore = [];    this.enqueueFront = enqueueFront;    this.enqueueBack = enqueueBack;    this.dequeueFront = dequeueFront;    this.dequeueBack = dequeueBack;    this.front = front;    this.back = back;    this.toString = toString;    this.empty = empty;}// 入队 - 队首function enqueueFront (element) {    this.dataStore.unshift(element);}// 出队 - 队首function dequeueFront () {    return this.dataStore.shift();}// 入队 - 队尾function enqueueBack (element) {    this.dataStore.push(element);}// 出队 - 队尾function dequeueBack (element) {    return this.dataStore.pop(element);}// 读取队首的元素function front () {    return this.dataStore[0];}// 读取队尾的元素function back () {    return this.dataStore[this.dataStore.length - 1];}// 显示队列内所有元素function toString () {    let retStr = ``;    for (let i = 0; i < this.dataStore.length; ++i) {        retStr += `${this.dataStore[i]}\n`;    }    return retStr;}// 判断队列是否为空function empty () {    if (this.dataStore.length === 0) {        return true;    } else {        return false;    }}

练习

一. 修改Queue类,形成一个Deque类。这是一个和队列类似的数据结构,允许从队列两端添加和删除元素,因此也叫双向队列。写一段测试程序测试该类。

// 双向队列类function Deque () {    this.dataStore = [];    this.enqueueFront = enqueueFront;    this.enqueueBack = enqueueBack;    this.dequeueFront = dequeueFront;    this.dequeueBack = dequeueBack;    this.front = front;    this.back = back;    this.toString = toString;    this.empty = empty;}// 入队 - 队首function enqueueFront (element) {    this.dataStore.unshift(element);}// 出队 - 队首function dequeueFront () {    return this.dataStore.shift();}// 入队 - 队尾function enqueueBack (element) {    this.dataStore.push(element);}// 出队 - 队尾function dequeueBack (element) {    return this.dataStore.pop(element);}// 读取队首的元素function front () {    return this.dataStore[0];}// 读取队尾的元素function back () {    return this.dataStore[this.dataStore.length - 1];}// 显示队列内所有元素function toString () {    let retStr = ``;    for (let i = 0; i < this.dataStore.length; ++i) {        retStr += `${this.dataStore[i]}\n`;    }    return retStr;}// 判断队列是否为空function empty () {    if (this.dataStore.length === 0) {        return true;    } else {        return false;    }}// 测试let d = new Deque();d.enqueueFront(`a`);d.enqueueFront(`b`);d.enqueueFront(`c`);d.enqueueFront(`d`);d.enqueueFront(`e`);console.log(d.dataStore); // ["e", "d", "c", "b", "a"]d.enqueueBack(`a`);d.enqueueBack(`b`);d.enqueueBack(`c`);d.enqueueBack(`d`);d.enqueueBack(`e`);console.log(d.dataStore); // ["e", "d", "c", "b", "a", "a", "b", "c", "d", "e"]d.dequeueFront();d.dequeueFront();console.log(d.dataStore); // ["c", "b", "a", "a", "b", "c", "d", "e"]d.dequeueBack();d.dequeueBack();d.dequeueBack();console.log(d.dataStore); // ["c", "b", "a", "a", "b"]

二. 使用前面完成的Deque类来判断一个给定单词是否为回文。

function isPalindrom (word) {    let d = new Deque();    let max = word.length;    for (let i = 0; i < max; ++i) {        d.enqueueBack(word[i]);    }    while (d.dataStore.length > 1) {        if (d.dequeueFront() !== d.dequeueBack()) {            return false;        }    }    return true;}// 示例console.log(isPalindrom(`racecar`)); // trueconsole.log(isPalindrom(`ada`)); // trueconsole.log(isPalindrom(`mazey`)); // false

转载于:https://www.cnblogs.com/mazey/p/8322361.html

你可能感兴趣的文章
深入了解Oracle ASM(二):ASM File number 1 文件目录
查看>>
Boosting(提升方法)之AdaBoost
查看>>
链接元素<a>
查看>>
Binding object to winForm controller through VS2010 Designer(通过VS2010设计器将对象绑定到winForm控件上)...
查看>>
Spring Boot实战笔记(二)-- Spring常用配置(Scope、Spring EL和资源调用)
查看>>
活现被翻转生命
查看>>
POJ 1228
查看>>
SwaggerUI+SpringMVC——构建RestFul API的可视化界面
查看>>
springmvc怎么在启动时自己执行一个线程
查看>>
流操作的规律
查看>>
Python基础学习15--异常的分类与处理
查看>>
javascript运算符的优先级
查看>>
React + Redux 入门(一):抛开 React 学 Redux
查看>>
13位时间戳和时间格式化转换,工具类
查看>>
vue router-link子级返回父级页面
查看>>
C# 通知机制 IObserver<T> 和 IObservable<T>
查看>>
Code of Conduct by jsFoundation
查看>>
div 只显示两行超出部分隐藏
查看>>
C#小练习ⅲ
查看>>
电源防反接保护电路
查看>>