【问题标题】:Maximum element in a stack java [closed]堆栈java中的最大元素[关闭]
【发布时间】:2017-01-03 22:20:55
【问题描述】:

https://www.hackerrank.com/challenges/maximum-element

ques 是执行三个查询 1-用于将元素添加到堆栈 2-用于弹出元素 3-用于打印最大元素 链接贴在上面 我无法在hackerrank 上获得6-7 个案例的输出

    int n,i;int in1,in2;
    Scanner sc=new Scanner(System.in);
    n=sc.nextInt();
    Stack<Integer> st=new Stack<Integer>();//stack for elements
    Stack<Integer> stmax=new Stack<Integer>(); // stack for storing maximum
        for(i=1;i<=n;i++)
        {
        in1=sc.nextInt();
        if(in1==1)
            {
                     in2=sc.nextInt();
                     if(st.size()==0)
                       {

                              stmax.push(in2);
                              st.push(in2);
                       }
                     else
                         {
                              if(in2>=stmax.peek())
                                  {

                              stmax.push(in2);
                              }
                               st.push(in2);

                          }    
        }
        if(in1==2)
            {
            if(st.peek()==stmax.peek())
                stmax.pop();
            st.pop();

        }
        if(in1==3)
            {
            System.out.println(stmax.peek());
        }

        }

【问题讨论】:

  • “无法得到输出”是什么意思?
  • @abhinav 提问时请具体简短...
  • 评论您的代码,并在发布之前让您的 IDE 对其进行格式化。使用拼写检查器。
  • 我无法通过hackerrank的7个测试用例。链接贴在上面。

标签: java algorithm performance stack max


【解决方案1】:

您的代码是正确的,但使用 if(st.peek().equals(stmax.peek())) 代替 if(st.peek()==stmax.peek()) 这将使您的代码通过所有测试用例

【讨论】:

  • 感谢您的回答!它现在正在工作。但你能解释一下你的解决方案吗?
  • 您的堆栈使用整数,而整数是与字符串相同的对象,因此 == 实际上意味着引用相等而不是值相等,您需要值相等
猜你喜欢
  • 2013-09-25
  • 1970-01-01
  • 2015-02-14
  • 1970-01-01
  • 1970-01-01
  • 2016-05-06
  • 2013-03-04
  • 2016-11-12
  • 1970-01-01
相关资源
最近更新 更多