堆排序-为什么PercolateDown()中的循环迭代(length/2)次
Heapsort - Why the loop in PercolateDown() iterates (length/2) times?
这里我们看到一个用C++实现的函数PercolateDown()。
我只是不明白为什么循环结束于,长度/2次?
此外,为什么构建堆中的循环从n/2开始?
当你构建最大/最小堆时,你不需要堆(PercolateDown)叶子,因为它们不能有比父母更大/更小的孩子。
请注意,教材中的C++源代码使用基于1的索引,即不使用CCD_ 1并且CCD_。
这与C++标准约定(数组、向量等,索引为0…n-1)不一致。
为了说明堆中的(基于1的)索引号(而不是值):
1
2 3
4 5 6 7
8 9 10
如果仔细阅读链接给出的文本,您会发现堆中i
位置的每个父节点在2*i
和2*i+1
位置都有子节点,前提是这些位置不超过数组的长度。
由于PercolateDown()算法将父母与其子女交换,因此只需要length/2
迭代。
此外,堆是自下而上构建的。因此,迭代从n/2
开始向上,即朝向位置1
。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- C++ 迭代器与对象与 length() 方法
- 堆排序-为什么PercolateDown()中的循环迭代(length/2)次