2.设计包含min函数的栈(栈)
定义栈的数据结构,要求添加一个min函数,能够得到栈的最小元素。
要求函数min、push以及pop的时间复杂度都是O(1)。package cn.emma.interview_2;
public class Stack {
public final static int MAX = 100;
private static int top;
private static int[] S = new int[MAX];
static int min;
private static Stack minStack = new Stack();
public boolean emptyStack(){
if(top == 0){
return true;
}
return false;
}
public static void push(int x){
if(top == 0){
min =x;
}
else{
min = (S[min] > x) ? ++top:min;
}
minStack.push(min);
S[top] = x;
}
public static int pop(){
minStack.pop();
return S[--top];
}
public static int minElement(){
return minStack.S[minStack.top];
}
public static int getMin(){
return min;
}
public static void main(String[] args) {
push(0);push(-1);
push(2);
push(-9);
push(10);
System.out.println(pop() + "\t" + pop() + "\t" + pop());
System.out.println(minElement());
}
}
分享到:
相关推荐
### 微软面试100题系列:涵盖的数据结构、算法与海量数据处理知识点解析 #### 一、概述 微软面试100题系列是由知名博主July创作的一套旨在帮助求职者准备技术面试的资源。该系列包含了11篇文章,总共300多道面试题...
因此,深入研究和理解微软面试题,如“ms100(微软面试100题)”,对于提升个人面试表现有着不可估量的价值。 #### 2. 二元查找树转排序双向链表问题 此题目是微软面试中一道经典算法题,要求在不创建新节点的前提...
本微软面试100题系列,共计11篇文章,300多道面试题,截取本blog索引性文章:程序员面试、算法研究、编程艺术、红黑树、数据挖掘5大系列集锦:http://blog.csdn.net/v_july_v/article/details/6543438,中的第一部分...
【微软面试100题系列】是一套针对应聘者准备微软公司面试的综合资源,包含了11篇文章,总计300多道问题,旨在帮助求职者深入理解和掌握与Windows操作系统和微软技术栈相关的知识,从而在面试中表现出色,顺利获得...
本资源包含了“微软面试100题完整版”,提供详尽的答案解析,对于准备微软、腾讯、百度等顶尖互联网企业面试的求职者来说,无疑是宝贵的复习材料。 这100题涵盖了算法设计、数据结构、操作系统、网络、数据库、软件...
以下是一些基于微软面试100题中的关键知识点的详细解释: 1. **数据结构**: - **数组**:基础的数据结构,用于存储同类型元素的集合,支持随机访问。 - **链表**:非连续存储,通过指针连接节点,插入和删除操作...
【微软面试100题】是一份集合了各种智力、逻辑和编程问题的文档,旨在测试应聘者在解决复杂问题、逻辑推理、算法理解和数学应用等方面的能力。以下是一些问题的解析: 1. 为什么下水道的井盖是圆的?—— 因为圆形...
根据提供的信息,我们可以总结并扩展出一系列与微软面试100题相关的知识点,特别是针对第一个题目:“把二元查找树转变成排序的双向链表”。 ### 知识点1:二元查找树(Binary Search Tree, BST)的概念 **定义:** ...
- **重要意义**:“微软面试100题系列PDF”不仅仅是一份面试题集,更是一种学习方法的体现。它激发了编程爱好者的学习热情,促进了技术交流与合作,是数据结构与算法领域不可或缺的一份宝贵资料。 - **未来发展**:...
微软面试100题系列是求职者准备微软技术面试的重要参考资料,它涵盖了各种技术领域的问题,旨在测试候选人的编程能力、算法理解、系统设计以及对微软相关产品和技术的熟悉程度。这个系列通常由一系列的问题组成,每...