数据结构与算法 Python 第 4 周:基本结构(上)“栈及应用”
1|0Notes
栈的模板
2|01:有效的括号
3|02:一维开心消消乐
4|03:强迫症老板和他的洗碗工
这里我用栈A来维护当前的元素,栈B来维护已经被取出的元素。
首先如果栈B是空的,那么就说明没有元素被取出,我可以先把[0,x]
放入 A 中,然后把元素x
取出再重新放入 B 中。
剩下的情况就是 B 不是空的,首先判断如果要取出的元素比最后一次取出的元素大,那么我们就把[B.top,x]
放入 A 中然后把x
取出放入B中。
如果x
比B.top
小,那么可以确定是,[0,B.top]
一定全部进入过A中,那么如果A.top
是x
的话x+1
一定已经从A中出来进入B中,否则就是不合法的情况
然后发现整个过程中是不需要维护A的
__EOF__

本文作者:PHarr
本文链接:https://www.cnblogs.com/PHarr/p/16573687.html
关于博主:前OIer,SMUer
版权声明:CC BY-NC 4.0
声援博主:如果这篇文章对您有帮助,不妨给我点个赞
本文链接:https://www.cnblogs.com/PHarr/p/16573687.html
关于博主:前OIer,SMUer
版权声明:CC BY-NC 4.0
声援博主:如果这篇文章对您有帮助,不妨给我点个赞
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律