码迷,mamicode.com
首页 > 其他好文 > 详细

剑指offer二十之包含min函数的栈

时间:2017-10-02 21:32:38      阅读:182      评论:0      收藏:0      [点我收藏+]

标签:一个   ide   span   题目   oid   import   code   数据结构   isp   

一、题目

  定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数。

二、思路

用一个栈dataStack保存数据,用另外一个栈minStack保存依次入栈最小的数。每次元素存入minStack的时候,如果该元素比minStack的栈顶元素小,则存入minStack,否则用minStack栈顶元素代替该元素存入minStack。

比如dataStack中依次入栈的元素为:5,  4,  3,  8,  10,  11,  12,  1

则minStack依次入栈的元素为:      5,  4,  3,  3,   3,   3,    3,    1

三、代码

技术分享
import java.util.Stack;

/*
用一个栈dataStack保存数据,用另外一个栈minStack保存依次入栈最小的数。每次元素存入minStack的时候,如果该元素比minStack的栈顶元素小,则存入minStack,否则用minStack栈顶元素代替该元素存入minStack。
比如dataStack中依次入栈的元素为:5,4,3,8,10,11,12,1
则minStack依次入栈的元素为:5,4,3,3,3,3,3,1
 */
public class Solution {
    Stack<Integer> dataStack = new Stack<Integer>(); //保存元素
    Stack<Integer> minStack = new Stack<Integer>(); //保存最小元素

    public void push(int value) {
        dataStack.push(value); //元素入dataStack
        if (minStack.isEmpty() || value < minStack.peek()) { //如果minStack为空,或者当前存入的元素小于minStack的栈顶元素,则把该元素存入minStack
            minStack.push(value);
        } else {
            minStack.push(minStack.peek());//如果minStack不为空且当前存入的元素大于或者等于minStack的栈顶元素,则把minStack栈顶元素存入minStack
        }
    }

    public void pop() {
        dataStack.pop();
        minStack.pop();
    }

    public int top() {
        return dataStack.peek();
    }

    public int min() {
        return minStack.peek();
    }
}
View Code

--------------------------------------------------------------------------------

参考链接:https://www.nowcoder.com/questionTerminal/4c776177d2c04c2494f2555c9fcc1e49

剑指offer二十之包含min函数的栈

标签:一个   ide   span   题目   oid   import   code   数据结构   isp   

原文地址:http://www.cnblogs.com/hezhiyao/p/7622258.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!