首页 > 其他 > 详细

【leetcode】3 minstack

时间:2015-05-07 23:43:16      阅读:246      评论:0      收藏:0      [点我收藏+]

构建MinStack,实现一系列操作,包括push,pop,top,minstack(返回栈中最小元素)

思路:利用原始栈,不过这里需要两个栈,一个栈mystack用于存储元素,另一个栈otherstack元素由小到大排列

关键:mystack进行push(x)时,判断x与mystack的top()元素大小,始终将小的元素如栈minstack,这样mystack的top()始终是最小的

mystack的pop操作也是类似,当mystack与otherstack的top元素相同时,两个元素同时删除,否则只删除mystack的top元素

class MinStack { public:

    stack<int> mystack;     stack<int> minstack;

    void push(int x) {        

    mystack.push(x);        

    if(minstack.empty()||x<=minstack.top())            

      minstack.push(x);     }

    void pop() {        

     if(!mystack.empty()){            

       if(mystack.top()==minstack.top())                

        minstack.pop();            

        mystack.pop();        

        }            

       }

    int top() {        

    return mystack.top();     }

    int getMin() {       

    return minstack.top();    

} };

【leetcode】3 minstack

原文:http://www.cnblogs.com/wygyxrssxz/p/4486186.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!