调试中...
调试中...
题目描述
题目描述
题解
题解
提交记录
提交记录
代码
代码
测试用例
测试用例
测试结果
测试结果
中等
相关标签
相关企业
提示

栈排序。 编写程序,对栈进行排序使最小元素位于栈顶。最多只能使用一个其他的临时栈存放数据,但不得将元素复制到别的数据结构(如数组)中。该栈支持如下操作:pushpoppeekisEmpty。当栈为空时,peek 返回 -1。

示例 1:

 输入:
["SortedStack", "push", "push", "peek", "pop", "peek"]
[[], [1], [2], [], [], []]
 输出:
[null,null,null,1,null,2]

示例 2:

 输入: 
["SortedStack", "pop", "pop", "push", "pop", "isEmpty"]
[[], [], [], [1], [], []]
 输出:
[null,null,null,null,null,true]

提示:

  1. 栈中的元素数目在[0, 5000]范围内。
通过次数
31.9K
提交次数
59.4K
通过率
53.7%

相关标签

相关企业

提示 1
排序数组的一种方法是遍历数组,并将每个元素按排序顺序插入到一个新数组中。你可以用一个栈实现吗?

提示 2
假设二级栈已排序。你能按顺序插入元素吗?你可能需要一些额外的存储空间。你可以使用什么额外的存储?

提示 3
保持二级栈的排序顺序,最大的元素在顶部。使用主栈进行额外的存储。

评论 (0)

《程序员面试金典(第 6 版)》独家授权
本书是原谷歌资深面试官的经验之作,帮助了许多想要加入脸书、苹果、谷歌等 IT 名企的求职者拿到 Dream offer。本专题的 100+ 编程面试题是在原书基础上精心挑选出来的,帮助你轻松应战 IT 名企技术面试。
© 2025 领扣网络(上海)有限公司
0 人在线
行 1,列 1
运行和提交代码需要登录
["SortedStack", "push", "push", "peek", "pop", "peek"]
[[], [1], [2], [], [], []]
Source