⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 minheap.h

📁 这些程序是本人学习数据结构时编的
💻 H
字号:
// MinHeap.h: interface for the MinHeap class.
// 
//  PROGRAM BY	:	SINGLE LAO
//  DATE		:   2004. 5. 25
//  VERSION		:	DEBUG 1.0 
//
//////////////////////////////////////////////////////////////////////

#if !defined(AFX_MINHEAP_H__81A02485_8C45_4F92_90AC_5E33C2E1C934__INCLUDED_)
#define AFX_MINHEAP_H__81A02485_8C45_4F92_90AC_5E33C2E1C934__INCLUDED_

#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000


#include <iostream>
#include "MinPQ.h"

using namespace std;

template<class Type>
class MinHeap:public MinPQ<Type>
{
public:
	int IsEmpty() const;
	int IsFull() const;
	void MakeEmpty();
	int RemoveMin(Type &x);
	int Insert(const Type & x);
	MinHeap(int maxSize = DefaultSize);
	MinHeap(Type arr[] ,int n);
	virtual ~MinHeap()
	{
		delete [] heap;
	};
	const MinHeap<Type>& operator = (const MinHeap& R);
private:
	enum { DefaultSize = 256}; 
	Type* heap;
	int MaxHeapSize;
	int CurrentSize;
	void FilterUp(int start);
	void FilterDown(int i,int m);
};

#endif // !defined(AFX_MINHEAP_H__81A02485_8C45_4F92_90AC_5E33C2E1C934__INCLUDED_)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -