码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 两个栈 实现一个队列


    请用两个栈,实现一个队列

    队列:

     概念:先进先出

     api : add delete length

     队列是逻辑结构,抽象模型

    简单的,可以用数组、链表实现

    复杂的队列服务,需要单独设计

    // 思路 

    1 定义一个原型对象  里面包涵  add    delete   length  

    2.  出列的时候要: 先进先出   

    /**

     * 两个栈  一个队列

     */

    export class myQueue{

        private stack1:number[] = []

        private stack2:number[] = []

        add(n:number){

            this.stack1.push(1)

        }

        delete():number | null{

            let res

            const stack1 = this.stack1

            const stack2 = this.stack2

            // 将stack1所有元素移动到stack2中

            while(stack1.length){

                const n = stack1.pop()

                if(n != null){

                    stack2.push(n)

                }

            }

            res = stack2.pop()

            // 将stack2中的元素返回给stack1

            while(stack2.length){

                const n = stack2.pop()

                if(n != null){

                    stack1.push(n)

                }

            }

            return res || null

        }

        get length ():number{

            return this.stack1.length

        }

    }

    时间复杂度 add O(1)  \delete O(n)

    空间复杂度整体是O(n)

  • 相关阅读:
    x11截屏源码(ubuntu18.04)
    技术解密Java Chassis 3超实用的可观测性
    【数据结构】带头双向循环链表的实现(C语言)
    美格智能最强音,让你了解真5G!毫米波ODU,万兆无线接入最后一公里
    相同wifi下,笔记本连接台式机上的虚拟机
    数组、list、set、map集合之间相互转换
    【调度算法】共享函数vs拥挤距离
    谣言检测论文精读——3.Detect Rumor and Stance Jointly by Neural Multi-task Learning
    网络通信 | 内网穿透
    html--彩虹马
  • 原文地址:https://blog.csdn.net/wanghongpu9305/article/details/126017715
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号