📄 seldefbst.h
字号:
// binaty serch tree defined by myself
# ifndef SELF_DEFINE_BST
# define SELF_DEFINE_BST
#include <iostream>
using namespace std;
template<class T>
class Queue
{
public:
Queue(int MaxQueueSize=10);
~Queue(){delete [] queue;}
bool IsEmpty() {return front==rear;}
bool IsFull()
{
if((rear+1)%MaxSize==front)
return 1;
else
return 0;
}
T First();//返回队首元素
T Last() ;//返回队尾元素
void enqueue(const T& x);
void dequeue(T& x);
private:
int front; //与第一个元素在反时针方向上相差一个位置
int rear; //指向最后一个元素
int MaxSize;//队列数组的大小
T *queue; //数组
};
template<class T>
Queue<T>::Queue(int MaxQueueSize)
{
MaxSize=MaxQueueSize;
queue=new T[MaxSize];
front=rear=0;
}
template<class T>
T Queue<T>::First()
{
if(IsEmpty())
return -1;
else
return queue[(front+1)%MaxSize];
}
template<class T>
T Queue<T>::Last()
{
if(IsEmpty())
return -1;
else
return queue[rear];
}
template<class T>
void Queue<T>::enqueue(const T& x)
{
if(IsFull())
{ cout<<"no memeory";return; }
rear=(rear+1)%MaxSize;
queue[rear]=x;
return;
}
template<class T>
void Queue<T>::dequeue(T& x)
{
if(IsEmpty())
{ cout<<"no element";return; }
front=(front+1)%MaxSize;
x=queue[front];
return;
}
template<class T>
class BSTNode { // 一般搜索二叉树的节点定义
public:
BSTNode() {
left = right = 0;
}
BSTNode(const T& el, BSTNode<T> *l = 0, BSTNode<T> *r = 0) {
key = el; left = l; right = r;
}
T key;
BSTNode<T> *left, *right;
};
/*template<class T>
class BST {
public:
BST()
{
root=0;
}
int countAllNode(BSTNode* r);
int countLeafNode(BSTNode* r);
int countRightNode(BSTNode* r);
void deleteLeafNode(BSTNode* r);
private:
BSTNode* root;
};*/
# endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -