码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 栈和队列总结


    基础知识

    1. 栈里面的元素在内存中是连续分布的么?
      答:不连续,python中collections.deque双向队列,用双向链表实现,而链表在内存中非连续分布。
      deque的pop和apend时间复杂度O(1),而list的pop和insert时间复杂度O(n)
      deque支持从两端添加和删除元素,所以既可以用作队列,也可以用作栈。
    • 用栈实现队列
      输入栈,输出栈,用List表示
      pop时,输出栈有值,直接弹出;输出栈为空,把输入栈所有值加入输出栈,再从输出栈弹出

    • 用队列实现栈
      双队列deque实现,
      一个队列为主,另一个队列为辅
      pop时,把主队列的除队尾的元素都加入辅助队列;把主队列和辅助队列交换,此时辅助队列中只有最后一个进入的元素,弹出辅助队列元素

    栈经典题目

    括号匹配

    括号匹配
    用栈,匹配左括号时,右括号先入栈,只需要比较当前元素与栈顶是否相等, 当遍历完字符串且stack为空,括号完全匹配。
    括号不匹配的3中情况:

    • 左括号多余
    • 无多余,但括号类型不匹配
    • 右括号多余

    字符串去重

    字符串去重

    逆波兰表达式

    逆波兰表达式

    队列经典题目

    滑动窗口最大值

    滑动窗口最大值
    用deque双头队列实现单调队列,即递增或递减的队列,pop和push不同场景不同写法

    求前K个高频元素

    求前K个高频元素
    python中借用库函数heapq,实现小顶堆,用小顶堆来实现优先级队列
    求前k大,用小顶堆
    求前K小,用大顶堆

    1. 先用dict实现数字与频次的映射
    2. 用小顶堆对频次排序
    3. 倒序输出小顶堆
  • 相关阅读:
    pytorch的backward()的底层实现逻辑
    Vue开发工具后浏览器报错
    Win11如何删除升级包?Win11删除升级包的方法
    AutoDWG DWG 转换 PDF 控制组件-ActiveX
    Qt设计一个自定义的登录框窗口
    d合并json
    java-php-python-毕业生交流学习平台计算机毕业设计
    QT小记:警告Use multi-arg instead
    ICPC 2019-2020 North-Western Russia Regional Contest
    LiveCharts2:简单灵活交互式且功能强大的.NET图表库
  • 原文地址:https://blog.csdn.net/Lucky_main/article/details/125459067
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号