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

剑指offer(15)

时间:2019-03-04 19:28:21      阅读:159      评论:0      收藏:0      [点我收藏+]

标签:min   tst   ack   new   pre   public   ISE   结构   lse   

 

题目:

  定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。

书中的思路:  技术图片

  按照这个思路我们很容易写出以下代码:

import java.util.Stack;

public class Solution {

    Stack stack = new Stack();
    Stack assistStack = new Stack();
    
    public void push(int node) {
        stack.push(node);
        if(assistStack.isEmpty()){
            assistStack.push(node);
        }else if((int)assistStack.peek()>node){
            assistStack.push(node);
        }else{
            assistStack.push((int)assistStack.peek());
        }
    }
    
    public void pop() {
        stack.pop();
        assistStack.pop();
    }
    
    public int top() {
        return (int)stack.peek();
    }
    
    public int min() {
        return (int)assistStack.peek();
    }
}

    设置一个辅助栈,存放当前最小的值。

 

剑指offer(15)

标签:min   tst   ack   new   pre   public   ISE   结构   lse   

原文地址:https://www.cnblogs.com/figsprite/p/10472325.html

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