如果我想让一个队列的自定义实现是正确的,我可以选择任何我想要的顺序(不是FIFO),但我必须始终尊重这样一个事实,即要删除的元素是定位为"head“的元素?
但是对于插入操作,我没有必要把元素放到尾部(比如放到FIFO中)?
发布于 2010-08-19 21:55:15
你是对的。javadoc明确说明了这一点:
队列通常但不一定以先进先出( FIFO )的方式对元素进行排序。其中的例外是优先级队列,它根据提供的比较器或元素的自然排序对元素进行排序,以及LIFO队列(或堆栈),它对元素进行后进先出( LIFO )排序。无论使用哪种排序,队列的头部都是可以通过调用remove()或poll()删除的元素。在FIFO队列中,所有新元素都插入到队列的尾部。其他类型的队列可以使用不同的放置规则。每个队列实现都必须指定其排序属性。
发布于 2010-08-19 21:58:29
你是对的。
Queue documentation甚至明确说明了这一点(强调我的):
以先进先出(first- in -first-out)的方式对元素进行排队,通常,但不一定是先出的()。..。无论使用哪种排序,队列的头部都是将通过调用
remove()或poll()删除的元素。
https://stackoverflow.com/questions/3522424
复制相似问题