#ifndef __BINARY_HEAP_H__
#define __BINARY_HEAP_H__ #include <iostream>
#include <vector>
#include <assert.h> template <typename Type>
class HeapStruct {
friend std::ostream& operator<< <Type>(std::ostream& out, const HeapStruct<Type>& heap); int capacity;
int size;
Type *elements;
void initialize(int maxElements);
public:
HeapStruct(int maxElements) { initialize(maxElements); }
void destroy();
void makeEmpty();
void insert(Type element);
Type deleteMin();
Type findMin();
bool isEmpty();
void buildHeap(Type a[], int num);
}; template <typename Type>
std::ostream& operator<<(std::ostream& out, const HeapStruct<Type>& heap)
{
out << "{";
int i;
for (i = ; i < heap.size; i++)
out << heap.elements[i] << ",";
out << heap.elements[i] << "}" << endl;
return out;
} template<typename Type>
inline void HeapStruct<Type>::initialize(int maxElements)
{
elements = (Type*)malloc((maxElements + ) * sizeof(Type));
assert(elements != nullptr);
capacity = maxElements;
size = ;
elements[] = Type();
} template<typename Type>
inline void HeapStruct<Type>::destroy()
{
free(elements);
} template<typename Type>
inline void HeapStruct<Type>::makeEmpty()
{
size = ;
} template<typename Type>
void HeapStruct<Type>::buildHeap(Type a[], int num)
{
if (size + num >= capacity)
{
Type *temp = elements;
while (capacity < size + num)
capacity *= ;
elements = (Type*)malloc((capacity + ) * sizeof(Type));
assert(elements != nullptr);
memcpy(elements, temp, (size + ) * sizeof(Type));
free(temp);
}
int build_frequency = ;
for (int i = ; i < num; ++i)
elements[i + ] = a[i];
size = num;
for (int i = num / ; i > ; i--)
{
int j, child;
Type lastEmement = elements[i];
for (j = i; j * <= size; j = child)
{
child = * j;
build_frequency += ;
if (child != size && elements[child] > elements[child + ])
child++;
if (elements[child] < elements[j])
elements[j] = elements[child];
else
break;
}
elements[j] = lastEmement;
}
std::cout << "构造频数为:" << build_frequency << endl;
} template<typename Type>
inline void HeapStruct<Type>::insert(Type element)
{
if (size + > capacity)
{
Type *temp = elements;
capacity *= ;
elements = (Type*)malloc((capacity + ) * sizeof(Type));
assert(elements != nullptr);
memcpy(elements, temp, (size + ) * sizeof(Type));
free(temp);
}
int i;
for (i = ++size; elements[i / ] > element; i /= )
elements[i] = elements[i / ];
elements[i] = element;
} template<typename Type>
inline Type HeapStruct<Type>::deleteMin()
{
Type min = elements[];
Type lastEmement = elements[size--];
if (size * <= capacity)
{
Type *temp = elements;
capacity = size;
elements = (Type*)malloc((capacity + ) * sizeof(Type));
assert(elements != nullptr);
memcpy(elements, temp, (size + ) * sizeof(Type));
free(temp);
}
int i, child;
for (i = ; i * <= size; i = child)
{
child = * i;
if (child != size && elements[child] > elements[child + ])
child++;
if (elements[child] < elements[i])
elements[i] = elements[child];
else
break;
}
elements[i] = lastEmement;
return min;
} template<typename Type>
inline Type HeapStruct<Type>::findMin()
{
return elements[];
} template<typename Type>
inline bool HeapStruct<Type>::isEmpty()
{
return size;
} #endif

二叉堆 C++实现的更多相关文章

  1. AC日记——二叉堆练习3 codevs 3110

    3110 二叉堆练习3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 给定N(N≤500,000)和N个整 ...

  2. codevs 3110 二叉堆练习3

    3110 二叉堆练习3 http://codevs.cn/problem/3110/ 题目描述 Description 给定N(N≤500,000)和N个整数(较有序),将其排序后输出. 输入描述 I ...

  3. 数据结构图文解析之:二叉堆详解及C++模板实现

    0. 数据结构图文解析系列 数据结构系列文章 数据结构图文解析之:数组.单链表.双链表介绍及C++模板实现 数据结构图文解析之:栈的简介及C++模板实现 数据结构图文解析之:队列详解与C++模板实现 ...

  4. POJ 2010 - Moo University - Financial Aid 初探数据结构 二叉堆

    考虑到数据结构短板严重,从计算几何换换口味= = 二叉堆 简介 堆总保持每个节点小于(大于)父亲节点.这样的堆被称作大根堆(小根堆). 顾名思义,大根堆的数根是堆内的最大元素. 堆的意义在于能快速O( ...

  5. 二叉堆(一)之 图文解析 和 C语言的实现

    概要 本章介绍二叉堆,二叉堆就是通常我们所说的数据结构中"堆"中的一种.和以往一样,本文会先对二叉堆的理论知识进行简单介绍,然后给出C语言的实现.后续再分别给出C++和Java版本 ...

  6. 二叉堆(二)之 C++的实现

    概要 上一章介绍了堆和二叉堆的基本概念,并通过C语言实现了二叉堆.本章是二叉堆的C++实现. 目录1. 二叉堆的介绍2. 二叉堆的图文解析3. 二叉堆的C++实现(完整源码)4. 二叉堆的C++测试程 ...

  7. 二叉堆(三)之 Java的实现

    概要 前面分别通过C和C++实现了二叉堆,本章给出二叉堆的Java版本.还是那句话,它们的原理一样,择其一了解即可. 目录1. 二叉堆的介绍2. 二叉堆的图文解析3. 二叉堆的Java实现(完整源码) ...

  8. 二叉堆(binary heap)

    堆(heap) 亦被称为:优先队列(priority queue),是计算机科学中一类特殊的数据结构的统称.堆通常是一个可以被看做一棵树的数组对象.在队列中,调度程序反复提取队列中第一个作业并运行,因 ...

  9. 在A*寻路中使用二叉堆

    接上篇:A*寻路初探 GameDev.net 在A*寻路中使用二叉堆 作者:Patrick Lester(2003年4月11日更新) 译者:Panic 2005年3月28日 译者序 这一篇文章,是&q ...

  10. 《Algorithms算法》笔记:优先队列(2)——二叉堆

    二叉堆 1 二叉堆的定义 堆是一个完全二叉树结构(除了最底下一层,其他层全是完全平衡的),如果每个结点都大于它的两个孩子,那么这个堆是有序的. 二叉堆是一组能够用堆有序的完全二叉树排序的元素,并在数组 ...

随机推荐

  1. TTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面。如果该页面是脚本,请添加处理程序。如果应下载文件,请添加 MIME 映射。

    解决办法一: 控制面板->打开或关闭windows功能->Internet信息服务->万维网服务->应用程序开发功能. 勾选上“.net扩展性”和“ASP.NET”,保存后,重 ...

  2. 在 Windows Forms 和 WPF 应用中使用 FontAwesome 图标

    前言 FontAwesome 大家都不陌生,精美的图标,出现在各式各样的网页中. 最近在做 Windows Forms 应用程序,要求美观,就想能不能把 FontAwesome 图标用上,于是就有了本 ...

  3. HTML5中的WebSocket

    在HTML5规范中,我最喜欢的Web技术就是正迅速变得流行的WebSocket API.WebSocket提供了一个受欢迎的技术,以替代我们过去几年一直在用的Ajax技术.这个新的API提供了一个方法 ...

  4. form表单的两种提交方式,submit和button的用法

    1.当输入用户名和密码为空的时候,需要判断.这时候就用到了校验用户名和密码,这个需要在jsp的前端页面写:有两种方法,一种是用submit提交.一种是用button提交.方法一: 在jsp的前端页面的 ...

  5. PHP变量处理之serialize

    官方定义: string serialize ( mixed $value ) serialize() 返回字符串,此字符串包含了表示 value 的字节流,可以存储于任何地方.这有利于存储或传递 P ...

  6. JS数组处理

    一.定义数组: 方法1 var myCars=new Array(); myCars[0]="Saab"; myCars[1]="Volvo"; myCars[ ...

  7. 微信支付 - iOS

    前言 大家都说微信支付很麻烦,我看了一下 就做一下记录吧 正文 一: 1.微信开发网站:https://open.weixin.qq.com 注册一个开发者账号,申请一个app,(大概7个工作日,但是 ...

  8. java多线程安全问题 静态函数的修饰

    /* 如果同步函数被静态修饰后,使用的锁是什么呢? 通过验证,发现不在是this.因为静态方法中也不可以定义this. 静态进内存是,内存中没有本类对象,但是一定有该类对应的字节码文件对象. 类名.c ...

  9. 读书笔记 effective c++ Item 17 使用单独语句将new出来的对象放入智能指针

    1. 可能会出现资源泄漏的一种用法 假设我们有一个获取进程优先权的函数,还有一个在动态分类的Widget对象上根据进程优先权进行一些操作的函数: int priority(); void proces ...

  10. (Jquery)避免数据相加小数点后产生多位数和计算精度损失

    /** * 加法运算,避免数据相加小数点后产生多位数和计算精度损失. * * @param num1加数1 | num2加数2 */ function numAdd(num1, num2) { var ...