定义具有未知数量子项的树
Defining trees with unknown number of children
我需要定义一个树,其中每个节点的子节点数量未知。它不能使用数组来完成,因为子项的数量可能被高估或低估。所以我需要使用链表,其中列表将是节点的子级。
这将如何完成
class emp
{
string name;
emp* parent;
employee* child;
};
struct employee
{
emp* junior;
employee* next;
};
在此代码中,在调用员工子级之前未定义员工,因此会给出错误。请提出更改建议。
在类定义之前向前声明employee
emp
。
struct employee;
class emp
{
//....
我个人会说你应该使用vector<employee>
或'list,而不是建立自己的链表。
另请注意,使用链表会增加相当多的额外内存使用量,因为每个节点的开销通常为 32-64 字节。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 部分定义/别名模板模板参数
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- #为""定义宏;静态";针对不同的上下文
- 如何确保C++函数在定义之前声明(如override关键字)
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在命名空间中定义函数还是限定函数
- 此代码是否违反一个定义规则
- 编译C++时未定义的引用
- 不同翻译单元中不可重载的非内联函数定义
- 为什么在定义函数之前先声明它
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 在类定义之后定义一个私有方法
- 使用用户定义函数的字符串反转
- 用户定义函数中的指针和输入
- vscode g++链路故障:体系结构x86_64的未定义符号
- 如何定义一个纯抽象基类