鱼C论坛

 找回密码
 立即注册
查看: 2395|回复: 0

[学习笔记] 顺序存储二叉树

[复制链接]
发表于 2018-5-1 11:30:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
《数据结构C++语言描述》 清华大学出版社    任燕编著

小弟改编程序使之可以运行,同时重载输出运算符,使之更加方便的显示顺序存储的二叉树

但是小弟感觉用这个程序好像有点像是用数组来意淫二叉树一样哈哈,就是一些数学关系

加油!
#include <iostream>
#include <assert.h>
#include <cstdbool>
#include <cstdlib>
#define DEFAULT_SEQTREE 100

using namespace std;

template <typename elemtype>
class SeqTree{
public:
        //顺序存储的树置空
        void clear();

        //取最后一个结点在顺序存储空间的下标
        int getFinalIndex();

        //返回树采用顺序存储的首地址
        elemtype *getInitialAddress();

        //取下标为i的结点(就是第i+1个结点)
        elemtype getNode(int i);

        //重载赋值运算符
        SeqTree operator=(SeqTree<elemtype> right);

        //设置最后一个结点在顺序存储空间的下标
        void setFinalIndex(int i);

        //设置下标为i的结点(就是第i+1个结点)的值
        void setNode(int i, elemtype value);

        //构造函数
        SeqTree();

        //析构函数
        virtual ~SeqTree();

        //拷贝初始化构造函数
        SeqTree(const SeqTree<elemtype> &seqT);

        //重载输出运算符
        template <typename out_put>
        friend ostream& operator<<(ostream& out,SeqTree<out_put> other);


protected:
        elemtype *initialAddress;                //树的顺序存储空间的首地址
        int finalIndex;                                        //按层次存放,最后一个结点在顺序存储空间的下标
};


//把一棵树顺序存储的空间置空
template <typename elemtype>
void SeqTree<elemtype>::clear(){
        if (initialAddress){
                delete[] initialAddress;
        }
        initialAddress = NULL;
        finalIndex = -1;
}

//取最后一个结点在顺序存储空间的下标
template <typename elemtype>
int SeqTree<elemtype>::getFinalIndex(){
        return finalIndex;
}

//返回树的存储的首地址
template <typename elemtype>
elemtype* SeqTree<elemtype>::getInitialAddress(){
        return initialAddress;
}

//取下标为i的结点
template <typename elemtype>
elemtype SeqTree<elemtype>::getNode(int i){
        if (i<0 || i>finalIndex){                //如果溢出就退出
                cerr << OVERFLOW;
                exit(0);
        }

        return initialAddress[i];
}


//重载赋值运算符
template <typename elemtype>
SeqTree<elemtype> SeqTree<elemtype>::operator=(SeqTree<elemtype> right){
        if (this != &right){
                finalIndex = right.finalIndex;
                if (finalIndex != -1){
                        // 给左边的树申请一个一样大的存储空间
                        initialAddress = new elemtype[finalIndex + 1];
                        assert(initialAddress != 0);
                        //把右边树的每个结点的数据域赋值给左边
                        for (int i = 0; i <= finalIndex; i++){
                                initialAddress[i] = right.initialAddress[i];
                        }
                }
        }

        return *this;                // 返回对象
}


//设置最后一个结点在顺序存储空间的下标
template <typename elemtype>
void SeqTree<elemtype>::setFinalIndex(int i){
        finalIndex = i;
}

//设置下标为i的结点的值
template <typename elemtype>
void SeqTree<elemtype>::setNode(int i, elemtype value){
        initialAddress[i] = value;
        if (i > finalIndex){
                finalIndex = i;
        }
}

//构造函数
template <typename elemtype>
SeqTree<elemtype>::SeqTree(){
        initialAddress = new elemtype[DEFAULT_SEQTREE];
        finalIndex = -1;
}

//析构函数
template <typename elemtype>
SeqTree<elemtype>::~SeqTree(){
        clear();
        cout << "清除完毕" << endl;
}

//拷贝初始化构造函数
template <typename elemtype>
SeqTree<elemtype>::SeqTree(const SeqTree<elemtype>& other){
        initialAddress = NULL;
        finalIndex = other.finalIndex;

        if (finalIndex != -1){
                initialAddress = new elemtype[finalIndex + 1];
                assert(initialAddress != 0);

                for (int i = 0; i < finalIndex + 1; i++){
                        initialAddress[i] = other.initialAddress[i];
                }
        }
}

//重载输出运算符
template <typename out_put>
ostream& operator<<(ostream& out, SeqTree<out_put> other){
        if (other.finalIndex != -1){
                for (int i = 0; i <= other.finalIndex; i++){
                        out << other.initialAddress[i] << "\t";
                }
                return out;
        }
        else{
                cout << "树为空" << endl;
        }
}





int main(void){
        SeqTree<int> seq1;
        for (int i = 0; i < 10; i++){
                seq1.setNode(i, i * 10);
        }
        cout << seq1 << endl;


        cout << seq1.getNode(0) << endl;
        cout << seq1.getNode(3) << endl;

        SeqTree<int> seq2;
        seq2 = seq1;
        cout << seq2 << endl;//测试赋值运算符的重载
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-24 06:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表