且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

linux下练习 c++ 有序二叉树

更新时间:2022-06-15 02:35:18

#include <iostream>
using namespace std;
typedef int T;
class bst//有序的二叉查找树
{
	struct Node
	{
		T data;
		Node * L;
		Node * R;
		Node(const T&d):data(d),L(),R(){}//将L或R初始化为0
		Node(const T&d,Node * l,Node * r):data(d),L(l),R(r){}
	};
	typedef Node* tree;
	Node * root;//根结点
	int n;//记录节点个数
public:
	bst():root(),n(){}
	void insert(tree& t,Node* p)//插入数据
	{
		if(t==NULL) t=p;
		else if(p->data<t->data) insert(t->L,p);
		else insert(t->R,p);
	}
	void insert(const T& d)
	{
		insert(root,new Node(d));
		++n;
	}
	tree& find(tree& t,const T& d)//查找,&代表指针本身
	{
		if(t==NULL) return t;//返回tree类型的
		else if(d==t->data) return t;
		else if(d<t->data) return find(t->L,d);
		else return find(t->R,d);
	}
	tree& find(const T& d)
	{
		return find(root,d);
	}
	void travel(tree t) const//遍历
	{
		if(t!=NULL)
		{
			travel(t->L);
			cout<<t->data<<" ";
			travel(t->R);
		}
	}
	void travel()
	{
		travel(root);
		cout<<endl;
	}
	bool empty()const//是否为空
	{
		return root==NULL;
	}
	bool remove(const T& d)//删除数据节点
	{
		tree& t=find(d);//引用,原来的地址
		if(t==NULL) return false;
		Node* p=t;
		if(t->L !=NULL) insert(t->R,t->L);//左子树插入到右子树中去
		t=t->R;//t指向右子树
		delete p;//删除结点空间
		--n;
		return true;
	}
	int size()const {return n;}
	void update(const T& olddata,const T& newdata)//修改数据
	{
		if(remove(olddata)) insert(newdata);//删除旧的,插入新的
	}
	const T& rdata()const
	{
		if(!root) throw "空";
		return root->data;
	}
	void clear(tree& t)//清空,释放内存
	{
		if(t!=NULL)
		{
			clear(t->L);
			clear(t->R);
			delete t;
			t=NULL;
			cout<<"内存释放完成!\n";
			n=0;
		}
	}
	void clear()
	{
		clear(root);
	}
	int height(tree t)//高度
	{
		if(t==NULL) return 0;
		int lh=height(t->L);
		int rh=height(t->R);
		return 1+(lh>rh?lh:rh);
	}
	int height()
	{
		return height(root);
	}
};

int main()
{
	bst b;
	b.insert(4);//插入
	b.insert(5);
	b.insert(-23);
	b.insert(24);
	b.insert(77);
	b.insert(20);
	b.update(20,28);//20修改为28
	b.remove(4);//删除4的节点
	b.travel();//遍历一下
	cout<<b.rdata()<<endl;
	return 0;
}

g++ -o tree.out tree.cpp

./tree.out

 

linux下练习 c++ 有序二叉树