首页 > Java > java教程 > 尽管比较器正确,但为什么我的 PriorityQueue 的 toString 输出混乱?

尽管比较器正确,但为什么我的 PriorityQueue 的 toString 输出混乱?

Patricia Arquette
发布: 2024-10-30 14:11:26
原创
417 人浏览过

Why is My PriorityQueue's toString Output Disordered Despite a Correct Comparator?

ToString 输出中的 PriorityQueue 顺序差异

该问题源于当比较器未对元素进行排序时错误使用 PriorityQueue 的 toString 方法

比较器错误

在给定的比较器 HuffmanComparator 中,应按如下方式修改代码,以优先考虑频率较低的节点:

<code class="java">public int compare(TreeNodeHuffman p1, TreeNodeHuffman p2) {
  if (p1.frequency > p2.frequency) return -1;
  if (p1.frequency < p2.frequency) return 1;
  return 0;
}</code>
登录后复制

toString 和轮询

虽然比较器现在是正确的,但 PriorityQueue 的 toString 方法并不能保证元素完全排序。为了获得排序后的元素,我们应该使用 while 循环逐个轮询项目:

<code class="java">while (!queue.isEmpty()) {
  System.out.println(queue.poll());
}</code>
登录后复制

这种方法确保堆结构在每次调用 poll 期间都是固定的,从而得到所需的元素顺序输出。

以上是尽管比较器正确,但为什么我的 PriorityQueue 的 toString 输出混乱?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板