如何在c++中创建树
How to create a tree in C++?
我想在C++
中创建一个树。我有父子关系和节点数量我想以某种方式存储这棵树。例如,如果我有一个图,我可以用邻接表,或者用向量的向量,或者邻接矩阵来存储它。但是树木呢?
例如,我有9个节点,9-1=8个父子关系:7- 2,7 - 3,7 - 4,3 - 5,3 - 6,5 - 8,5 - 9,6 -1。我想存储这棵树,例如计算从最老的父结点(7)到子结点(在本例中是7-3-5-8或7-3-5-9,路径长度为4)的最长路径。
假设你的图是有向的,你不知道节点的数字范围,我建议你使用map<int, vector<int> >
作为你的邻接表:
#include <vector>
#include <map>
#include <iostream>
using namespace std;
int main()
{
map< int, vector<int> > adj_list;
int edges;
cin >> edges;
for ( int i=0; i<edges; ++i ){
int u, v;
cin>>u>>v;
adj_list[u].push_back(v);
//adj_list[v].push_back(u); // uncomment this line if your graph is directed
}
for ( auto it = adj_list.begin(); it != adj_list.end(); ++it ){
const auto& children = it->second;
cout << "children of " << it->first << " is:" << endl;
for ( int i=0; i < children.size(); ++i ){
cout << children[i] << " ";
}
cout << endl;
}
}
输入8
7 2
7 3
7 4
3 5
3 6
5 8
5 9
6 1
children of 3 is:
5 6
children of 5 is:
8 9
children of 6 is:
1
children of 7 is:
2 3 4
使用此结构map
的每个键以vector<int>
的形式保存该节点的邻接表。这意味着您可以通过遍历adj_list[1]
访问节点1的子节点。
我将通过让节点包含指向节点的(智能)指针向量来存储树。例如:
struct tree_node
{
int value;
std::vector<std::unique_ptr<tree_node>> children;
};
如果我有一个图,我可以用邻接表存储它,或者使用向量的向量,或者邻接矩阵。但是树木呢?
但是树是一种图。
Boost中甚至有一个关于(家族)树的具体例子。图文档的邻接表
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 使用std::multimap迭代器创建std::list
- 在全局变量中保存类的实例以重新创建类(创建"backup")
- 使用CMake创建QML插件
- 如何在c++中为模板函数实例创建快捷方式
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- OpenCV EqualizeHist()从彩色图像创建黑白图像
- 试图在visual studio上用C++创建一个桌面应用程序
- std::threads可以从Windows DLL中的全局变量创建/销毁吗?
- 如何在C++20中创建模板别名的推导指南
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 如何创建一个空的全局类并在启动时实例化它
- 无法创建抽象类的实例
- 链接到自行创建的dll失败
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++类内存结构中创建"spacer"?
- 终端不会为C++文件创建.exe文件吗
- 在createdialog创建的窗口中捕获用于编辑控件的OnMouseMove消息