两个栈实现队的最佳解是什么?

曾经面试过这个问题,当时也看过类似的讲解,用一个栈负责push,另一个栈负责pop,入队的时候全部放入A栈中,出队的时候,将其全部压入B栈,这样最上方就是要输出的值。但是面试官对我说还能优化吗?我没能回答,最后说还有更优解,请问要怎么做?
...全文
117 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
GKatHere 2021-04-08
  • 打赏
  • 举报
回复
将pop栈倒序排列,就可共享一内存。
maguangzhi 2021-04-07
  • 打赏
  • 举报
回复
引用 楼主 高度中二患者的回复:
曾经面试过这个问题,当时也看过类似的讲解,用一个栈负责push,另一个栈负责pop,入队的时候全部放入A栈中,出队的时候,将其全部压入B栈,这样最上方就是要输出的值。但是面试官对我说还能优化吗?我没能回答,最后说还有更优解,请问要怎么做?
栈利用率最高的代码见"C++程序设计精要教程”第11章
maguangzhi 2021-04-07
  • 打赏
  • 举报
回复
栈利用率最高的代码见“C++程序设计精要教程“第11章。
maguangzhi 2021-04-07
  • 打赏
  • 举报
回复
一共有三种方法,有一种空间利用率最高,两栈的空间均可利用。源代码参见《C++程序设计精要教程》第11章之运算符重载实例。

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧