Google面试题(六)

转载 2011年01月11日 12:31:00

题目:对现在的Stack(栈)数据结构进行改进,加一个min()功能,使之能在常数,即O(1),时间内给出栈中的最小值。可对push()和pop()函数进行修改,但要求其时间复杂度都只能是O(1)。 

分析:要使pop,push,min都是O(1),所以肯定要牺牲点空间 

思路:1:在stack的数据结构中加两个个字段,如 

     typedef struct { 

           int data[MAX]; 

           int top; 

           int min; 

           int second; 

     }stack; 

          pop,push的时候都去栈顶元素,所以是O(1) 

          min的时候取stack的min字段,所以也是O(1) 

         每次push的时候进行比较,如果当前push的元素比stack->min小,则用当前元素替换stack->min,用原来的min替换second。如果当前push的元素比stack->min大,但比second小,则用当前元素替换stack->second。于是达到了取min的效果,程序如下 

          int push(stack * s,int x){ 

                 ASSERT(s!=NULL); 

                 if(s->top>=MAX)  

                 { 

                        printf("Stack overload!"); 

                        return -1; 

                 } 

                 s->data[s->top++]=x; 

                 if(x<s->min) 

                  s->min=x; 

                 return 0; 

        } 
        每次pop的时候进行比较,如果pop的元素为min,则用second替换min。于是达到了取min的效果,程序如下 
        int pop(stack *s,int *x) 

        { 

               ASSERT(s!=NULL); 

              if(s->top<=0) 

              { 

                      printf("Stack Empty!"); 

                      return -1; 

             } 

            (*x)=s->data[s->top--]; 
            if(x==s->min) s->min=s->second; 
           return 0; 



int min( stack *s,int *x ) 



      ASSERT(s!=NULL); 

      (*x)=s->min; 

     return 0; 




思路2:设置辅助栈ass,记录每个状态下的最小值,每次插入时,得到辅助栈当前值,和插入的值比较 

如果小则插入到最小值栈的就是它,否则就是原来的最小值,通过这种方式,pop,push,min三个都是 

O(1)算法的。 

typedef struct { 

     int data[MAX]; 

     int top; 

}stack; 

STATIC int push_stack(stack *s,int x) 



      ASSERT((s!=NULL)); 

      if(s->top>=MAX) 

      { 

            printf("Stack overload"); 

            return -1; 

      } 

     s->data[s->top++]=x; 

     return 0; 



STATIC int pop_stack(stack *s,int *x) 



      ASSERT(s!=NULL); 

      if(s->top<=0) 

      { 

              printf("Stack Empty"); 

              return -1; 

       } 

       (*x)=s->data[s->top--]; 

       return 0; 



int push(stack *main,stack *ass,int x) 



       ASSERT((main!=NULL)&&(ass!=NULL)); 

       int temp; 

       pop_stack(ass,&temp); 

       push_stack(main,x); 

       if(x<temp) 

       { 

               push_stack(ass,temp); 

               push_stack(ass,x); 

       } 

       else 

       { 

                push_stack(ass,temp); 

                push_stack(ass,temp); 

       } 

       return 0; 



int pop(stack *main,stack *ass,int *x) 



        ASSERT((main!=NULL)&&(ass!=NULL)); 

       int temp; 

       pop_stack(ass,&temp); 

       pop_stack(main,x); 

       return 0; 



int min(stack *ass,int *x) 



       ASSERT((main!=NULL)&&(ass!=NULL)); 

       pop_stack(ass,x); 

       push_stack(ass,(*x)); 

       return 0; 

相关文章推荐

GOOGLE面试题集锦

  • 2014年01月17日 18:36
  • 36KB
  • 下载

google面试题.pdf

  • 2011年11月24日 16:29
  • 192KB
  • 下载

一道有趣的GOOGLE面试题——找出至少一个重复元素

一道有趣的GOOGLE面试题——找出至少一个重复元素 题目: 一个大小为n的数组,里面的数都属于范围[0, n-1],有不确定的重复元素,找到至少一个重复元素,要求O(1)空间和O(n)时...

Google, Baidu, Tencent 面试题总结

  • 2010年03月06日 03:52
  • 207KB
  • 下载

#google面试题14#找出两个排序数组的合并后的中位数

given sorted int[] A, int[] B. How would you find the maiden that would have been if both were combi...

【白话经典算法系列之十一】一道有趣的GOOGLE面试题 --【解法2】

微博http://weibo.com/MoreWindows已开通,欢迎关注。本系列文章地址:http://blog.csdn.net/MoreWindows/article/category/859...

Google面试题 数组中第K小的数字

Google面试题 数组中第K小的数字 二分逼近 二分查找

Google面试题——蓄水问题

问题: 有一块矩形土地被划分成 N×M 个正方形小块,每块是一平方米。这些小块高低不平,每一小块地都有自己的高度H(i, j)米。水可以由任意一块地流向周围四个方向的四块地中,但不能直接流入对角相连...
  • yahohi
  • yahohi
  • 2012年12月11日 16:23
  • 1223

【算法】一道有趣的GOOGLE面试题 --【解法2】

int Repeat(int *a, int n) { for(int i = 0; i < n; i++) { if(a[i] > 0) //判断条件 { if(a[ a[i] ]...

15个Google面试题以及答案~~~~你会几个?

1、 村子里有100对夫妻,其中每个丈夫都瞒着自己的妻子偷情。村里的每个妻子都能立即发现除自己丈夫之外的其他男人是否偷情,唯独不知道她自己的丈夫到底有没有偷情。村里的规矩不容忍通奸。任何一个妻子,一旦...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Google面试题(六)
举报原因:
原因补充:

(最多只允许输入30个字)