多叉树定义与遍历-----从零开始的数据结构

一.多叉树的定义:

• 多叉树本质上就是二叉树的延申,二叉树是特殊的多叉树

二叉树每一个节点都有两个子节点 ,那么 "多叉树" 每一个节点都有任意的 子节点

用代码表示就是:

二叉树节点:

cpp 复制代码
class TreeNode{
   public:
     int val;
     TreeNode* left;
     TreeNode* right;

     TreeNode(int x) : val(x) , left(nullptr) , right(nullptr){}
};

多叉树节点:任意的子节点-----用数组!

cpp 复制代码
class TreeNode{
   public:
     int val;
     vector<TreeNode*> children;
};

二叉树相关知识:

二叉树---从零开始的数据结构学习-CSDN博客

二叉树遍历----从零开始的数据结构-CSDN博客

补充:森林的定义

森林就是多叉树的集合,单独一颗多叉树是特殊的森林。

代码表示: 用list列表

cpp 复制代码
list<Node> forest;

每一个node都是一个多叉树的根节点

利用bfs和dfs从头节点遍历下去,是不是很像哈希表的遍历?

二.多叉树遍历

1.递归遍历(DFS):

cpp 复制代码
class TreeNode{
   public:
     int val;
     vector<TreeNode*> children;
};

void traverse(TreeNode* root){
    if (root == nullptr) return;


    //前序
    for (TreeNode* child : root->children){
        traverse(child);
    }

    //后序
}

前序在递归函数前面,后序在递归函数后

没有中序位置是因为可能会大于2,因此讨论中序没有意义

多叉树每一个节点的子节点在数组中刚好从左往右排列

2.层序遍历(BFS):

多叉树的层序遍历和二叉树的层序遍历相同。

写法一:最简单,不记录深度
cpp 复制代码
#include<iostream>
#include<vector>
#include<queue>
using namespace std;

class TreeNode{
  public:
     int val;
     vector<TreeNode*> children;
};

void levelOrderTraverse(TreeNode* root){
    if (root == nullptr) return;

    queue<TreeNode*> q;
    q.push(root);
    while(!q.empty()){
        TreeNode* cur = q.front();
        q.pop(); 
        cout << cur->val << endl;

        for (TreeNode* temp : cur->children){
            q.push(temp);
        }
    }
}
写法二: 常规,记录深度
cpp 复制代码
#include<iostream>
#include<vector>
#include<queue>
using namespace std;


class TreeNode{
  public:
    int val;
    vector<TreeNode*> children;
};


void levelOrderTraverse(TreeNode* root){
    if (root == nullptr)return;
    
    int depth = 1;//深度
    queue<TreeNode* > q;
    q.push(root);

    while(!q.empty()){
        int size = q.size();
        for (int i = 0; i < size; i++){
            TreeNode* cur = q.front();
            q.pop();

            for (TreeNode* temp : cur->children){
                q.push(temp);
            }
        }
        depth++;
    }
}

每一层在队列中的元素出队之后,depth加一

写法三: 使用于不同路径权重的情况
cpp 复制代码
#include<iostream>
#include<vector>
#include<queue>
using namespace std;


class TreeNode{
  public:
     int val;
     vector<TreeNode*> children;
};

class state{
   public:
    TreeNode* Node;
    int depth;//路径

    state(TreeNode* node, int depth) :Node(node) , depth(depth){}
};

void levelOrderTraverse(TreeNode* root){
    if (root == nullptr) return;

    queue<state> q;
    q.push(state(root,1)); //根节点深度当作1
    
    while(!q.empty()){
        state cur = q.front();
        q.pop();
        
        int depth = cur.depth;
        for (TreeNode* temp : cur.Node->children){
             
            q.push(state(temp,depth+1));
        }
    }

}

每一个层路径节点默认比上一层多一,在不同情景中进行更改即可。

结语:

如果喜欢我的文章,不妨点一个免费的赞和收藏。

你们的支持都是我更新路上最大的动力

相关推荐
t***5442 小时前
Dev-C++ 中使用 Clang 调试有哪些常见问题
开发语言·c++
遇见你的雩风2 小时前
Java --- 网络原理(三)
java·开发语言·网络
会编程的土豆2 小时前
Go语言零基础入门:从0到能写程序(超详细版)
开发语言·后端·golang
itzixiao2 小时前
L1-058 6翻了(15分)[java][python]
java·开发语言·python·算法
小小码农Come on2 小时前
单例 QtObject 全局配置
开发语言·前端·javascript
hakesashou2 小时前
python如何保存img文件
开发语言·python
珹洺2 小时前
C++AI多模型聊天系统(四)SSH反向隧道/虚拟局域网(VLAN)调用本地Ollama大模型
c++·人工智能·ssh
小π军2 小时前
STL之multiset 常见API介绍
数据结构·c++·算法
MarkHD2 小时前
调度、监控与部署:Python自动化任务全栈实践
开发语言·python·自动化
同勉共进2 小时前
并发编程系列(二)—— store, load 与 RMW
c++·arm·并发编程·x86·store·load·rmw