cci-Q3.2 设计栈可以返回最小值

原文:

How would you design a stack which, in addition to push and pop, also has a function min which returns the minimum element? Push, pop and min should all operate in O(1) time.

译文:

实现一个栈,除了push和pop操作,还要实现min函数以返回栈中的最小值。 push,pop和min函数的时间复杂度都为O(1)。

可以通过改造栈中元素的方式,让栈中的每一个元素自身保存着从他到栈底的最小值,需要对push函数进行改写。

栈中元素 NodeMin

public class NodeMin {

    int value;
    int min;

    public NodeMin(int value, int min) {
        this.value = value;
        this.min = min;
    }
}

改写push(),增加min()

public class StackMin extends Stack<NodeMin> {

    public StackMin() {
    }

    public void push(int value) {
        int min = Math.min(value, min());
        super.push(new NodeMin(value, min));
    }

    public int min() {
        if (this.isEmpty()) {
            return Integer.MAX_VALUE;
        } else {
            return super.peek().min;
        }
    }
}

testcase

    public static void main(String args[]) {
        StackMin stackm = new StackMin();
        System.out.println(stackm.isEmpty());
        System.out.println(stackm.min());
        stackm.push(2);
        System.out.println(stackm.min());
        stackm.push(1);
        System.out.println(stackm.min());
        stackm.pop();
        System.out.println(stackm.min());
    }

如果栈内元素较多,每一个元素还需要保存最小值,会浪费很多存储空间,可以在栈中在添加一个栈用来保存最小值。

public class StackMin2 extends Stack<Integer> {

    Stack<Integer> mins;

    public StackMin2() {
        mins = new Stack<>();
    }

    public void push(int value) {
        if (value <= min()) {
            mins.push(value);
        }
        super.push(value);
    }

    public Integer pop() {
        int value = super.pop();
        if (value == min()) {
            mins.pop();
        }
        return value;
    }

    public int min() {
        if (this.isEmpty()) {
            return Integer.MAX_VALUE;
        } else {
            return this.mins.peek();
        }
    }
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值