美文网首页
面试题30:包含min函数的栈

面试题30:包含min函数的栈

作者: 潘雪雯 | 来源:发表于2020-05-12 18:48 被阅读0次

题目

定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的min函数。在该栈中,调用min、push及pop的时间复杂度都是O(1)。

解题思路

  1. 定义两个栈,一个用来存放数据stack1,一个作为辅助栈stack2存在每次新加入数据时,保持辅助栈中的栈顶是最小值。
  2. 在push()函数中进行压栈操作,每个进入stack1的数据data,都和stack2的栈顶元素进行比较,若data<stack2.top(),则同时向stack1和stack2压入数据。若data>stack2.top()则向stack2中压入stack2.top()。这样就可以让辅助栈stack2的栈顶保持最小元素。

代码

class Solution{
  private:
    stack<int> stack1;
    stack<int> stack2;
  public:
    void push(int value)
    {
        stack1.push(value);//数据栈加入一个元素
        //判断辅助栈是否为空,新加入元素是否小于辅助栈栈顶元素
        if(stack2.empty() || value < stack2.top())
        {
            stack2.push(value);//小的话,加入辅助栈
        }
        else
        {   //大的话,辅助栈中加入一个自己的栈顶元素,保持最小元素在栈顶
            stack2.push(stack2.top());
        }
    }

    void pop()
    {
        if(!stack1.empty())
        {
            stack1.pop();
            stack2.pop();
        }
    }
    int top()
    {
        return stack1.top();;
    }
    int min()
    {
        return stack2.top();
    }
};

完整代码见Github

相关文章

  • 剑指offer第六天

    面试题21 包含min函数的栈 实现一个能够得到栈的最小元素的min函数,在该栈中调用min,push,pop的时...

  • 剑指offer第二版-30.包含min函数的栈

    本系列导航:剑指offer(第二版)java实现导航帖 面试题30:包含min函数的栈 题目要求:定义栈的数据结构...

  • 剑指offer学习笔记:4.3 举例让抽象问题具体化

    面试题21:包含min函数的栈定义一个数据结构,请在该类型中实现一个能够得到栈中最小元素的min函数。在该栈中,调...

  • 30、包含min函数的栈

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

  • 面试题30:包含min函数的栈

    题目描述: 定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数。 解题思路: 引入一个辅助栈,用...

  • 面试题30:包含min函数的栈

    实现栈的数据结构,包含min方法可以以O(1)的时间复杂度获得栈中的最小值 每入栈一次,就与辅助栈顶比较大小,如果...

  • 面试题30:包含min函数的栈

    题目 定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的min函数。在该栈中,调用min、push及po...

  • 面试题30:包含min函数的栈

    题目:定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的min函数。在该栈中,调用min、push和po...

  • 面试题30:包含min函数的栈

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

  • 面试题30:包含min函数的栈

    题目:定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的min函数。在该栈中,调用min,push及po...

网友评论

      本文标题:面试题30:包含min函数的栈

      本文链接:https://www.haomeiwen.com/subject/ojlinhtx.html