热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c–在arr[0]处使用root的二进制堆有什么好处?

我正在数组arr上写一个二进制堆.除叶节点之外的每个节点都有两个子节点.根可以是arr[0]或arr[1].在Whyinaheapimplementedbyarraytheinde

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

除叶节点之外的每个节点都有两个子节点.

根可以是arr [0]或arr [1].

在Why in a heap implemented by array the index 0 is left unused?接受的答案说arr [1]更快.

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

将根置于arr [0]有什么好处?

解决方法:

我是回答你关联的问题的人.

在具有基于0的数组的语言中创建具有arr [1]根的二进制堆是愚蠢的.不是因为它浪费了大量的空间,而是因为它造成了不必要的混乱代码而没有任何好处.

为什么代码混乱?因为它破坏了我们作为程序员多年来一直工作的基本规则:数组从0开始.如果你想要一个包含100个项目的数组,你就这样声明:

int a[100];

除了二进制堆.因为在1973年将一些原始二进制堆代码从Algol(其数组基于1)转换为C(基于0的数组)的白痴没有改变子计算和父计算的大脑,我们最终得到了在这一个特殊情况下,您需要分配101个项目:

int a[101];

当有人在不一致的情况下打电话给那个人时,他想出了一个似是而非的表演论点.

是的,在计算左子索引的代码中有一个额外的增量指令,在计运算符的父索引时有一个额外的减量指令.在二进制堆的更广泛的上下文中,这两个指令对使用堆的任何程序的运行时间没有实际的区别.没有.如果差异是可测量的,那肯定会有噪音.您的计算机上还有许多其他事情会对您的程序性能产生更大的影响.

如果您正在编写需要高性能优先级队列的程序,那么您首先要使用二进制堆做什么?如果你真的要在你的优先级队列中存储大量的东西,你可能应该使用像Pairing堆这样的东西,它会胜过二进制堆,虽然内存成本更高.

C STL priority_queue,Java PriorityQueue和python的heapq都使用基于0的二进制堆.编写这些包的人了解性能方面的考虑因素.如果使用基于1的二进制堆获得显着的性能提升,他们就会这样做.他们使用0-based堆应该告诉你,基于1的堆的任何性能增益都是虚幻的.

有关更完整的讨论,请参见http://blog.mischel.com/2016/09/19/but-thats-the-way-weve-always-done-it/.


推荐阅读
  • 本文节选自《NLTK基础教程——用NLTK和Python库构建机器学习应用》一书的第1章第1.2节,作者Nitin Hardeniya。本文将带领读者快速了解Python的基础知识,为后续的机器学习应用打下坚实的基础。 ... [详细]
  • 2020年9月15日,Oracle正式发布了最新的JDK 15版本。本次更新带来了许多新特性,包括隐藏类、EdDSA签名算法、模式匹配、记录类、封闭类和文本块等。 ... [详细]
  • Ihavetwomethodsofgeneratingmdistinctrandomnumbersintherange[0..n-1]我有两种方法在范围[0.n-1]中生 ... [详细]
  • 本文详细介绍了 PHP 中对象的生命周期、内存管理和魔术方法的使用,包括对象的自动销毁、析构函数的作用以及各种魔术方法的具体应用场景。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • 本文是Java并发编程系列的开篇之作,将详细解析Java 1.5及以上版本中提供的并发工具。文章假设读者已经具备同步和易失性关键字的基本知识,重点介绍信号量机制的内部工作原理及其在实际开发中的应用。 ... [详细]
  • 在《Cocos2d-x学习笔记:基础概念解析与内存管理机制深入探讨》中,详细介绍了Cocos2d-x的基础概念,并深入分析了其内存管理机制。特别是针对Boost库引入的智能指针管理方法进行了详细的讲解,例如在处理鱼的运动过程中,可以通过编写自定义函数来动态计算角度变化,利用CallFunc回调机制实现高效的游戏逻辑控制。此外,文章还探讨了如何通过智能指针优化资源管理和避免内存泄漏,为开发者提供了实用的编程技巧和最佳实践。 ... [详细]
  • 深入解析 Synchronized 锁的升级机制及其在并发编程中的应用
    深入解析 Synchronized 锁的升级机制及其在并发编程中的应用 ... [详细]
  • DAO(Data Access Object)模式是一种用于抽象和封装所有对数据库或其他持久化机制访问的方法,它通过提供一个统一的接口来隐藏底层数据访问的复杂性。 ... [详细]
  • 零拷贝技术是提高I/O性能的重要手段,常用于Java NIO、Netty、Kafka等框架中。本文将详细解析零拷贝技术的原理及其应用。 ... [详细]
  • 本教程详细介绍了如何使用 Spring Boot 创建一个简单的 Hello World 应用程序。适合初学者快速上手。 ... [详细]
  • Java高并发与多线程(二):线程的实现方式详解
    本文将深入探讨Java中线程的三种主要实现方式,包括继承Thread类、实现Runnable接口和实现Callable接口,并分析它们之间的异同及其应用场景。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 本报告对2018年湘潭大学程序设计竞赛在牛客网上的时间数据进行了详细分析。通过统计参赛者在各个时间段的活跃情况,揭示了比赛期间的编程频率和时间分布特点。此外,报告还探讨了选手在准备过程中面临的挑战,如保持编程手感、学习逆向工程和PWN技术,以及熟悉Linux环境等。这些发现为未来的竞赛组织和培训提供了 valuable 的参考。 ... [详细]
  • 工作8年后薪资从1万跃升至7万,网友惊叹:本科学历实属难得
    一位本科毕业生在工作8年后,凭借扎实的技术能力和不断的学习提升,成功将月薪从1万元提高到7万元,引发了网友们的广泛赞叹。这一成就不仅体现了个人的努力与坚持,也反映了当前技术领域对高素质人才的迫切需求。 ... [详细]
author-avatar
ya的sky
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有