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

一.多叉树的定义:

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

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

用代码表示就是:

二叉树节点:

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));
        }
    }

}

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

结语:

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

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

相关推荐
澈20717 小时前
C++并查集:高效解决连通性问题
java·c++·算法
郝学胜-神的一滴18 小时前
Qt 入门 01-01:从零基础到商业级客户端实战
开发语言·c++·qt·程序人生·软件构建
测试员周周18 小时前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
宏笋18 小时前
C++ thread的detach()方法详解
c++
旖-旎19 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
摇滚侠19 小时前
@Autowired 和 @Resource 的区别
java·开发语言
Wy_编程19 小时前
go语言中的结构体
开发语言·后端·golang
SeaTunnel19 小时前
(八)收官篇 | 数据平台最后一公里:数据集成开发设计与上线治理实战
java·大数据·开发语言·白鲸开源
大卡片20 小时前
C++的基础知识点
开发语言·c++
米罗篮20 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程