设计一个支持
push,pop,top操作,并能在常数时间内检索到最小元素的栈。实现
MinStack类:
MinStack()初始化堆栈对象。void push(int val)将元素val推入堆栈。void pop()删除堆栈顶部的元素。int top()获取堆栈顶部的元素。int getMin()获取堆栈中的最小元素。示例 1:
输入: ["MinStack","push","push","push","getMin","pop","top","getMin"] [[],[-2],[0],[-3],[],[],[],[]] 输出: [null,null,null,null,-3,null,0,-2] 解释: MinStack minStack = new MinStack(); minStack.push(-2); minStack.push(0); minStack.push(-3); minStack.getMin(); --> 返回 -3. minStack.pop(); minStack.top(); --> 返回 0. minStack.getMin(); --> 返回 -2.提示:
-231 <= val <= 231 - 1pop、top和getMin操作总是在 非空栈 上调用push,pop,top, andgetMin最多被调用3 * 104次
cppclass MinStack { private: stack<int> st; stack<int> minSt; public: MinStack() { } void push(int val) { st.push(val); if(minSt.empty()||val<=minSt.top()) { minSt.push(val); } } void pop() { if(st.top()==minSt.top()) minSt.pop(); st.pop(); } int top() { return st.top(); } int getMin() { return minSt.top(); } }; /** * Your MinStack object will be instantiated and called as such: * MinStack* obj = new MinStack(); * obj->push(val); * obj->pop(); * int param_3 = obj->top(); * int param_4 = obj->getMin(); */
LeetCode 155. 最小栈
Liangwei Lin2026-05-10 17:06
相关推荐
Cat_Rocky4 小时前
k8s-持久化存储,粗浅学习知识领航员4 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景薛定e的猫咪4 小时前
因果推理研究方向综述笔记释怀°Believe4 小时前
Spring解析ooseabiscuit5 小时前
Laravel4.x:现代PHP框架的奠基之作如何原谅奋力过但无声5 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)平行侠5 小时前
037插入排序 - 整理扑克牌的算法ECT-OS-JiuHuaShan6 小时前
彻底定理化:从量子纠缠到量子代谢节奏昂6 小时前
【一份基础软件的下载地址和安装地址】