JavaScript 用两个栈实现队列

/*
* 把一个栈完全倒进另一个栈就可以用两个栈模拟实现一个队列
* */
let inStack = []
let outStack = []

function pushNode (node) {
    inStack.push(node)
}
function popNode () {
    if (inStack.length === 0 && outStack.length === 0) return
    if (outStack.length === 0) {
        for (let i = inStack.length ; i > 0 ; i--) {
            outStack.push(inStack.pop())
        }
    }
    return outStack.pop()
}

pushNode(8)
pushNode(9)
pushNode(1)

console.log(popNode())
console.log(popNode())
console.log(popNode())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是使用双端队列实现撤销重做功能的类的示例代码: ```javascript class UndoRedo { constructor() { this.undoStack = []; // 撤销 this.redoStack = []; // 重做 } // 执行操作并将操作添加到撤销中 doAction(action) { this.undoStack.push(action); this.redoStack = []; // 清空重做 action.execute(); } // 撤销操作 undo() { const action = this.undoStack.pop(); if (action) { this.redoStack.push(action); action.undo(); } } // 重做操作 redo() { const action = this.redoStack.pop(); if (action) { this.undoStack.push(action); action.redo(); } } } // 示例使用 // 创建一个操作类 class Action { constructor(value) { this.value = value; } execute() { console.log('执行操作:', this.value); } undo() { console.log('撤销操作:', this.value); } redo() { console.log('重做操作:', this.value); } } const undoRedo = new UndoRedo(); // 执行操作并撤销 undoRedo.doAction(new Action('操作1')); undoRedo.doAction(new Action('操作2')); undoRedo.undo(); // 撤销操作2 // 重做操作 undoRedo.redo(); // 重做操作2 ``` 在上述示例中,我们定义了一个UndoRedo类,其中包含两个,undoStack用于存储执行的操作,redoStack用于存储被撤销的操作。doAction方法用于执行操作并将其添加到撤销中,undo方法用于撤销最近的操作,redo方法用于重做最近被撤销的操作。 我们还创建了一个Action类作为示例操作,其中包含execute方法用于执行操作,undo方法用于撤销操作,redo方法用于重做操作。 在示例使用部分,我们创建了UndoRedo实例,并通过doAction方法执行两个操作。然后调用undo方法进行撤销操作,并调用redo方法进行重做操作。 你可以根据你的需求来定义自己的操作类和具体的操作逻辑。这个类可以帮助你实现撤销和重做功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值