根位于 arr[0] 的二叉堆有什么好处

2024-01-05

我正在数组上写一个二进制堆arr.

除叶节点外,每个节点都有两个子节点。

根可以位于arr[0] or arr[1].

接受的答案在为什么在数组实现的堆中索引 0 未被使用? https://stackoverflow.com/questions/22900388/why-in-a-heap-implemented-by-array-the-index-0-is-left-unused says arr[1]是比较快的。

但该答案下面的一条评论说,大多数实施都扎根于arr[0].

扎根有什么好处arr[0]?


我是回答您链接的问题的人。

创建根位于的二进制堆arr[1]在具有从 0 开始的数组的语言中这是愚蠢的。不是因为它浪费了一点点空间,而是因为它创建了不必要的混乱代码,却没有任何好处。

为什么代码很混乱?因为它打破了我们作为程序员多年来一直遵循的基本规则:数组从 0 开始。如果您想要一个包含 100 个项目的数组,您可以这样声明:

int a[100];

除了二进制堆。因为一些白痴在 1973 年将原始二进制堆代码从 Algol(其数组从 1 开始)转换为 C(从 0 开始数组),但没有头脑来更改子级和父级计算,所以我们最终得到了结果在这种特殊情况下,要保存 100 个项目,您必须分配 101 个:

int a[101];

当有人就这种不一致问题给那个人打电话时,他提出了一个似是而非的绩效论点。

是的,代码中有一个额外的递增指令用于计算左子索引,并且在计算子父索引时有一个额外的递减指令。在二进制堆的更广泛的上下文中,这两条指令对使用该堆的任何程序的运行时间没有实际影响。没有任何。如果差异甚至是可测量的,那么它肯定会很吵。您的计算机上发生的许多其他事情将对您的程序性能产生更大的影响。

如果您正在编写一个需要高性能优先级队列的程序,那么您首先要使用二进制堆做什么?如果你真的要在优先级队列中存储大量的东西,你可能应该使用像配对堆这样的东西,它的性能优于二进制堆,尽管内存成本更高。

C++ STLpriority_queue, 爪哇PriorityQueue,以及python的heapq都使用从0开始的二进制堆。编写这些包的人了解性能考虑因素。如果使用基于 1 的二进制堆能够显着提高性能,他们就会这样做。他们使用基于 0 的堆应该告诉您,从基于 1 的堆获得的任何性能提升都是虚幻的。

请参阅我的博客文章但这就是我们一直以来的做法! https://blog.mischel.com/2023/01/19/but-thats-the-way-weve-always-done-it/进行更完整的讨论。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

根位于 arr[0] 的二叉堆有什么好处 的相关文章

随机推荐

  • 设置 SOLR SSL 属性

    当我使用提供的 Apache SOLR 启动脚本 版本 6 6 0 时 该脚本创建并执行一个 java 命令行 该命令行具有两组 SSL 属性 其相关元素设置为相同的值 一组的名称如下javax net ssl 而另一组的名称如下solr
  • AWS-CDK 错误:此 VPC 中没有“公共”子网。使用不同的 VPC 子网选择

    我正在将 CDK 堆栈从 0 30 0 移植到 0 39 0 我的 AWS 账户有一个预定义的 VPC 我只需将其导入堆栈即可 相同的子网在 0 30 0 中工作正常 但在 0 39 0 中收到错误消息 此 VPC 中没有 公共 子网 请使
  • JOIN 后选择不同的值

    我有3张桌子 Vehicle vehicle id vehicle type 1 motorcycle 2 car 3 van Owners person id vehicle id date bought 1 1 2009 1 2 200
  • Visual Studio:类型或命名空间名称“属性”不存在

    There s 另一个线程 https stackoverflow com questions 9163316 type or namespace name properties does not exist 16270872这里关于这个
  • 集合视图单元格之间不需要的空间 组合布局

    我正在将集合视图用于场景 我创建了一个自定义的构图布局 如下所示 然而 当滚动时 有一个不需要的空间单元格的第二部分之间 它发生在不同的细胞类型中 我检查了间距或插图 但无法找出原因 构图布局部分 struct UIHelper stati
  • Angular:“找不到类型为‘object’的不同支持对象‘[object Object]”。 NgFor 仅支持绑定到 Iterables,例如数组

    我创建了一个 Angular 应用程序 它从 json 文件获取数据 但我在 html 中显示数据时遇到问题 很多变数都是荷兰语 对此我感到抱歉 我对这一切也有点陌生 这是我的服务 import Injectable from angula
  • Latex IEEE 模板:在多列乳胶内容中使用单列表[关闭]

    Closed 这个问题不符合堆栈溢出指南 help closed questions 目前不接受答案 I am trying to use this IEEE template https www sharelatex com templa
  • CSS背景图片在移动浏览器上放大

    我的网站上有一个部分使用 CSS 背景图像 该网站是here http www robertsteilberg com 您可以在 联系方式 部分中看到我在哪里有固定背景图像 这是图像的当前 CSS hs contact section co
  • 如何使用 ActionScript 获取响应标头? (闪光)

    所以 我有一个像 www example com stream 这样的 URL 我需要向此 url 发出任何请求并获取 Http Rewspons 标头 如下所示 HTTP 1 0 200 OK Content type video x f
  • 如何处理 JSF 2 中的会话过期和 ViewExpiredException?

    考虑以下场景 在会话超时 过期 后 我单击 JSF 表单的提交按钮 浏览器显示一些异常消息 ViewExpiredException 无法恢复视图上下文 我想要做的是 在会话过期后自动重定向到网站的主页 这样做的机制是什么 任何帮助将非常感
  • 无法在 iOS 上创建托管对象上下文

    我创建了一个非核心数据项目 我现在想使用核心数据 在构建阶段 我将二进制文件与 CoreData framework 链接起来 在我的应用程序委托方法中 我想手动创建一个托管对象上下文 如下所示 NSManagedObjectContext
  • 如何恢复使用策略=我们的合并?

    我正在使用一个存储库 其中几周前执行了合并 我们刚刚发现它使用了 strategy ours标志 它应该使用 strategy option ours 标志 因此不会对 HEAD 应用任何更改 但是 我们需要应用这些更改 Git 已经识别出
  • python中的正交距离回归:返回值的含义

    我正在关注正交距离回归 http docs scipy org doc scipy reference odr html id1拟合因变量和自变量均带有误差的数据的方法 我用一条简单的直线拟合数据 我的模型是y ax b 现在 我可以编写代
  • 如何为版本 2 和版本 3 设置不同的 PYTHONPATH?

    假设我将 PYTHONPATH 设置为 bashrc如下 export PYTHONPATH PYTHONPATH ver2packages 当我检查 Python 3 中的 python 路径时 python3 gt gt gt impo
  • 更改完整日历中单元格的颜色

    我需要更改 arshaw 完整日历的单元格颜色 我的要求是 公司提供的假期列表的 td 单元格应该有相同的颜色 员工休假列表的 td 单元格应该具有相同的颜色 我们如何实现这一点 我能够改变事件的颜色 但不能改变单元格的颜色 另外 如果我们
  • 如何以编程方式更改 Android 谷歌地图 v2 中的语言

    我有一个应用程序 您可以在其中更改设置中的区域设置 目的是能够在应用程序内拥有与系统区域设置不同的区域设置 我也希望能够设置地图的语言 我只能找到 设置手机的系统语言 之类的答案 这不是我要找的 有没有办法以编程方式或从 xml 设置地图的
  • Matlab聚类编码-绘制散点图

    我有一年期间每日 每年的能源消耗数据集 我想显示该数据集的散点图 分为我期望存在的四个集群 由于四个季节的差异 我知道 matlab cluster 函数可以做到这一点 但我的统计数据非常生疏 我希望得到一些指导来确定哪个函数最好使用 Th
  • 如何在 Mac 版“Visual Studio Code”中取消链接/从 Git 存储库注销

    一直在玩这个微软编辑器 相当不错 但缺少一些最基本的 UI 位 不知道如何从我之前登录的 Git 存储库中取消链接 注销 退出并重新打开该软件不起作用 而且 没用说 我有很多我使用的存储库 任何想法 在侧面板的底部 有一个帐户图标 通常位于
  • 简单的CSS固定标题

    使以下页眉成为固定页眉的最简单方法是什么 http presentationtube com header php http presentationtube com header php我应该移动标题中的菜单元素吗 templatemo
  • 根位于 arr[0] 的二叉堆有什么好处

    我正在数组上写一个二进制堆arr 除叶节点外 每个节点都有两个子节点 根可以位于arr 0 or arr 1 接受的答案在为什么在数组实现的堆中索引 0 未被使用 https stackoverflow com questions 2290