`
EmmaZhao
  • 浏览: 33432 次
  • 性别: Icon_minigender_2
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

微软面试100题

 
阅读更多

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题系列之高清完整版PDF文档[带目录+标签]by_July

    ### 微软面试100题系列:涵盖的数据结构、算法与海量数据处理知识点解析 #### 一、概述 微软面试100题系列是由知名博主July创作的一套旨在帮助求职者准备技术面试的资源。该系列包含了11篇文章,总共300多道面试题...

    ms100(微软面试100题)答案整理版 绝对清晰

    因此,深入研究和理解微软面试题,如“ms100(微软面试100题)”,对于提升个人面试表现有着不可估量的价值。 #### 2. 二元查找树转排序双向链表问题 此题目是微软面试中一道经典算法题,要求在不创建新节点的前提...

    微软面试100题系列之高清完整版PDF文档[带目录+标签]

    本微软面试100题系列,共计11篇文章,300多道面试题,截取本blog索引性文章:程序员面试、算法研究、编程艺术、红黑树、数据挖掘5大系列集锦:http://blog.csdn.net/v_july_v/article/details/6543438,中的第一部分...

    微软面试100题系列

    【微软面试100题系列】是一套针对应聘者准备微软公司面试的综合资源,包含了11篇文章,总计300多道问题,旨在帮助求职者深入理解和掌握与Windows操作系统和微软技术栈相关的知识,从而在面试中表现出色,顺利获得...

    微软面试100题完整版(题目答案齐全)

    本资源包含了“微软面试100题完整版”,提供详尽的答案解析,对于准备微软、腾讯、百度等顶尖互联网企业面试的求职者来说,无疑是宝贵的复习材料。 这100题涵盖了算法设计、数据结构、操作系统、网络、数据库、软件...

    微软面试100题(含参考答案).pdf

    以下是一些基于微软面试100题中的关键知识点的详细解释: 1. **数据结构**: - **数组**:基础的数据结构,用于存储同类型元素的集合,支持随机访问。 - **链表**:非连续存储,通过指针连接节点,插入和删除操作...

    微软面试100题.doc

    【微软面试100题】是一份集合了各种智力、逻辑和编程问题的文档,旨在测试应聘者在解决复杂问题、逻辑推理、算法理解和数学应用等方面的能力。以下是一些问题的解析: 1. 为什么下水道的井盖是圆的?—— 因为圆形...

    微软面试100题完美答案版

    根据提供的信息,我们可以总结并扩展出一系列与微软面试100题相关的知识点,特别是针对第一个题目:“把二元查找树转变成排序的双向链表”。 ### 知识点1:二元查找树(Binary Search Tree, BST)的概念 **定义:** ...

    v_JULY_v微软面试100题系列PDF

    - **重要意义**:“微软面试100题系列PDF”不仅仅是一份面试题集,更是一种学习方法的体现。它激发了编程爱好者的学习热情,促进了技术交流与合作,是数据结构与算法领域不可或缺的一份宝贵资料。 - **未来发展**:...

    微软面试100题系列by_July.zip

    微软面试100题系列是求职者准备微软技术面试的重要参考资料,它涵盖了各种技术领域的问题,旨在测试候选人的编程能力、算法理解、系统设计以及对微软相关产品和技术的熟悉程度。这个系列通常由一系列的问题组成,每...

Global site tag (gtag.js) - Google Analytics