У меня есть этот класс (я знаю, ужасно.. Я только начинаю работать с классами в С++, и указатели мне так тяжело даются.. :)):
class Tree{
private:
Tree* Left;
Tree* Right;
int info;
Tree* GetTree(int num){
return new Tree(num);
}
public:
Tree() :info(0) ,Left(nullptr), Right(nullptr) {};
Tree(int num) : info(num), Left(nullptr) , Right(nullptr){};
Tree(int num,Tree* L,Tree* R) : info(num), Left(L), Right(R) {};
void SetLeft(Tree* L){Left = L;};
void SetRight(Tree* R){Right = R;};
void SetLeft(Tree L){Left = &L;};
void SetRight(Tree R){Right = &R;};
void SetLeft(int num){Left = GetTree(num);};
void SetRight(int num){Right = GetTree(num);};
void SetInfo(int num){info = num;};
Tree GetLeft(){return (Left==nullptr) ? Tree() : *Left;};
Tree GetRight(){return (Right==nullptr) ? Tree() : *Right;};
Tree* GetLeft(bool ptr){return Left;};
Tree* GetRight(bool ptr){return Right;};
int GetInfo(){return info;};
};
(В основном этот класс создает дерево с 2 листьями (еще 2 дерева), слева и справа, и у каждого из них есть еще 2 листа и т. д.), поэтому я сделал это:
Tree temp(5);
Tree* tem = &temp;
temp.SetInfo(10);
temp.SetLeft(5);
temp = temp.GetLeft();
cout << tem->GetInfo();
надеясь, что tem будет указывать на начало дерева, но он просто следует за temp.. есть ли способ сделать это легко?
Можете ли вы, ребята, помочь мне с классом? Мне трудно комбинировать указатели и классы S:
Спасибо!
Tree
и присвоить его левому потомку. Затем вы можете использовать его отдельно. 12.10.2013Tree
. Затем вы хотите добавить в него левого дочернего элемента. После этого вам нужно назначить этот объект его левым дочерним элементом. Фактически, после этого другой (правильный) ребенок будет уничтожен (и информация в родителе тоже будет потеряна). Итак, прежде чем сделать это, вы должны скопировать свое дерево, чтобы сохранить правильного потомка. Но вы не можете сделать это с одним объектом. 12.10.2013