二叉树(数组表示)

.h 文件:

#pragma once

class Tree
{
public:
    Tree(int size, int* pRoot);
    ~Tree();
    int* SearchNode(int nodeIndex);  //查找
    bool AddNode(int nodeIndex, int direction, int* pNode);//添加
    bool DeleteNode(int nodeIndex, int* pNode);//删除
    void TreeTraverse();//遍历
private:
    int* m_pTree;  
    int m_Size;
};

.cpp 文件:

#include<iostream>
#include "Tree.h"
using namespace std;

Tree::Tree(int size, int* pRoot)
{
    m_Size = size;
    m_pTree = new int[size];

    for (int i = 0; i < size; ++i)
    {
        m_pTree[i] = 0;
    }

    m_pTree[0] = *pRoot;
}

Tree::~Tree()
{
    delete[] m_pTree;
    m_pTree = nullptr;
}

int* Tree::SearchNode(int nodeIndex)
{
    if (nodeIndex < 0 || nodeIndex >= m_Size)return nullptr;
    if (m_pTree[nodeIndex] == 0)return nullptr;

    return &m_pTree[nodeIndex];
}

bool Tree::AddNode(int nodeIndex, int direction, int* pNode)
{
    if (nodeIndex < 0 || nodeIndex >= m_Size)return false;  //判断父节点索引是否正确
    if (m_pTree[nodeIndex] == 0)return false;  //判断父节点是否为空

    if (direction == 0) //左
    {
        if (nodeIndex * 2 + 1 >= m_Size)return false; //判断左孩子索引是否正确
        if (m_pTree[nodeIndex * 2 + 1] != 0)return false; //左孩子不为0说明已经有数据

        m_pTree[nodeIndex * 2 + 1] = *pNode;
    }
    if (direction == 1)//右
    {
        if (nodeIndex * 2 + 2 >= m_Size)return false;
        if (m_pTree[nodeIndex * 2 + 2] != 0)return false;

        m_pTree[nodeIndex * 2 + 2] = *pNode;
    }
    return true;
}

bool Tree::DeleteNode(int nodeIndex, int* pNode)
{
    if (nodeIndex < 0 || nodeIndex >= m_Size)return false;
    if (m_pTree[nodeIndex] == 0)return false;

    *pNode = m_pTree[nodeIndex];
    m_pTree[nodeIndex] = 0;

    return true;
}

void Tree::TreeTraverse()
{
    for (int i = 0; i < m_Size; ++i)
    {
        cout << m_pTree[i] << " ";
    }
}

测试代码:

#include<iostream>
#include"Tree.h"
using namespace std;

int main()
{
    int root = 3;
    Tree* pt = new Tree(10,&root);
    int node1 = 5;
    int node2 = 8;
    int node3 = 2;
    int node4 = 6;
    int node5 = 9;
    int node6 = 7;

    pt->AddNode(0, 0, &node1);
    pt->AddNode(0, 1, &node2);

    pt->AddNode(1, 0, &node3);
    pt->AddNode(1, 1, &node4);

    pt->AddNode(2, 0, &node5);
    pt->AddNode(2, 1, &node6);
    
    int node = 0;
    pt->DeleteNode(6, &node);
    cout << node << endl;

    pt->TreeTraverse();
    cout << endl;

    int *p = pt->SearchNode(2);
    cout << *p << endl;

    delete pt;

    return 0;
}

猜你喜欢

转载自www.cnblogs.com/chengmf/p/12454562.html
今日推荐