java中的Stack类效率为什么这么慢

起因是在刷leetcode84题柱状图中最大的矩形时,我用的Stack类作为栈使用,结果AC了之后有180ms左右的执行时延,这当然很离谱。

 

然后我去看了一个7ms的答案,发现区别只是他用的栈是自己用数组实现的。

那么这就很奇怪了,按道理说Stack类底层用的也应该是数组吧。不应该会慢这么多。

所以百度了一下,得到如下资料。

 然后我使用了Deque类下的ArrayDeque和LinkedList分别作栈试了下,结果也很奇怪。

ArrayDeque:

LinkedList:

 奇怪的地方在于,我之前一篇博客分析过Deque类和Queue类。这里

按道理讲,LinkedList比ArrayDeque适合作为栈使用,因为效率高。但是在leetcode编辑器中却相反了,我考虑是不是因为栈里存的是整型,所以导致的这种原因。

结论就是,按照这一题的AC情况来说,要想最快,就自己实现个数组栈。否则就用ArrayDeque来作栈使用。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值