Проверка, является ли двоичное дерево идеальным - PullRequest
0 голосов
/ 08 ноября 2018

У меня есть задание, касающееся двоичных деревьев, но функция, которая должна проверять, является ли она совершенной, вызывает ошибку сегментации, и я не знаю почему. Если задание уже пришло с функцией, которая задает глубину узла, я пытаюсь сравнить глубину как левого, так и правого узла, чтобы увидеть, равны ли они, и имеет ли узел как левого, так и правого потомка. Вот код:

#ifndef TREE_H_
#define TREE_H_

#include <string>
#include <sstream>
#include "exception.h"

class SimpleTree;

class TreeNode {
private:
int value;
TreeNode *left, *right;

int depth() const;
void removeChilds();
bool isLeaf() const;

public:
TreeNode(int);
TreeNode(int, TreeNode*, TreeNode*);

bool isFull() const;
int internalNodes() const;
bool isPerfect() const;
bool isDegenerate() const;

friend class SimpleTree;
};

TreeNode::TreeNode(int val) : value(val), left(0), right(0) {}

TreeNode::TreeNode(int val, TreeNode* le, TreeNode* ri)
: value(val), left(le), right(ri) {}

void TreeNode::removeChilds() {
if (left != 0) {
    left->removeChilds();
    delete left;
    left = 0;
}
if (right != 0) {
    right->removeChilds();
    delete right;
    right = 0;
}
}

bool TreeNode::isFull() const {
if(left == 0 && right == 0){
    return true;
}
if(left != 0 && right != 0){
    return (left->isPerfect() && right ->isPerfect());
}
return false;       
}

int TreeNode::internalNodes() const {
int cont = -1;

if(left == 0 && right == 0){
    cont = 0;   
}else {
    if(left != 0 || right != 0){
        cont = 1;
        if(left != 0){
            cont = cont + left->internalNodes();
        }
        if(right != 0){
            cont = cont + right->internalNodes();
        }
    }
}
return cont;
}

int TreeNode::depth() const {
int le = -1;
int ri = -1;
int de = -1;

if (left != 0) {
    le = left->depth();
}
if (right != 0) {
    ri = right->depth();
}
de = (le > ri)? le : ri;
return (de + 1);
}

bool TreeNode::isPerfect() const {
int ri = right->depth();
int le = left->depth();
if(left == 0 && right == 0){
    return true;
}
if(left != 0 && right != 0){
    if(ri == le){
        return (left->isPerfect() && right ->isPerfect());
    }
}
return false;       
}

bool TreeNode::isLeaf() const {
return (left == 0 && right == 0);
}


bool TreeNode::isDegenerate() const {
if(left != 0){
    if(right != 0){
        return false;
    }else{
        return left->isDegenerate();
    }
}else{
    if(left !=0){
        return false;
    }else{
        return right->isDegenerate();
    }
}
return false;
}

class SimpleTree {
private:
TreeNode *root;
void caseOne();
void caseTwo();
void caseThree();
void caseFour();

public:
SimpleTree(int);
~SimpleTree();
bool empty() const;
bool isFull() const;
int internalNodes() const;
bool isPerfect() const;
bool isDegenerate() const;
};

SimpleTree::SimpleTree(int option) {
switch (option) {
    case  1: caseOne(); break;
    case  2: caseTwo(); break;
    case  3: caseThree(); break;
    default: caseFour(); break;
}
}

void SimpleTree::caseOne() {
TreeNode *a, *b, *c, *d;

a = new TreeNode(4);
b = new TreeNode(5);
c = new TreeNode(2, a, b);

a = new TreeNode(6);
b = new TreeNode(7);
d = new TreeNode(3, a, b);

root = new TreeNode(1, c, d);
}

void SimpleTree::caseTwo() {
TreeNode *a, *b, *c, *d, *e;

a = new TreeNode(8);
b = new TreeNode(9);
c = new TreeNode(4, a, b);

a = new TreeNode(10);
b = new TreeNode(11);
d = new TreeNode(5, a, b);

e = new TreeNode(2, c, d);

a = new TreeNode(6);
b = new TreeNode(7);
c = new TreeNode(3, a, b);

root = new TreeNode(1, e, c);
}   

void SimpleTree::caseThree() {
TreeNode *a, *b, *c;

a = new TreeNode(6);

b = new TreeNode(5, a, 0);

c = new TreeNode(4, 0, b);

a = new TreeNode(3, c, 0);

b = new TreeNode(2, 0, a);

root = new TreeNode(1, b, 0);
}

void SimpleTree::caseFour() {
root = new TreeNode(1);
}

SimpleTree::~SimpleTree() {
if (root != 0) {
    root->removeChilds();
}
delete root;
root = 0;
}

bool SimpleTree::empty() const {
return (root == 0);
}

bool SimpleTree::isFull() const {
if (!empty()) {
    return root->isFull();
}
return false;
}

int SimpleTree::internalNodes() const {
if (!empty()) {
    return root->internalNodes();
}
return 0;
}

bool SimpleTree::isPerfect() const {
if (!empty()) {
    return root->isPerfect();
}
return false;
}

bool SimpleTree::isDegenerate() const {
if (!empty()) {
    return root->isDegenerate();
}
return false;
}

#endif /* EVALTREE_H_ */
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...