层序遍历通过队列实现,按从上到下、从左到右顺序访问节点。首先定义TreeNode结构,包含val、left和right指针。遍历时将根节点入队,循环取出队首节点,访问其值后将其左右子节点依次入队,直至队列为空。基础版本输出节点值,进阶版本按层分组返回vector<vector<int>>,每轮记录当前层大小,用for循环处理该层所有节点,再将子节点入队。时间复杂度O(n),空间复杂度O(w),w为树的最大宽度。

二叉树的层序遍历,也叫广度优先遍历,是按照从上到下、从左到右的顺序访问树中每一层的节点。在C++中,通常借助队列(queue)来实现这一过程。
首先需要定义二叉树的节点结构,包含数据域和左右子节点指针。
struct TreeNode {
int val;
TreeNode *left;
TreeNode *right;
TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};
核心思想是:将根节点入队,然后不断取出队首节点,访问其值,并将其左右子节点(如果存在)依次入队,直到队列为空。
步骤说明:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include <queue>
using namespace std;
<p>void levelOrder(TreeNode* root) {
if (!root) return;</p><pre class='brush:php;toolbar:false;'>queue<TreeNode*> q;
q.push(root);
while (!q.empty()) {
TreeNode* node = q.front();
q.pop();
cout << node->val << " ";
if (node->left) q.push(node->left);
if (node->right) q.push(node->right);
}}
有时需要将每一层的节点值分组返回,比如返回 vector<vector<int>>。这时可以在每轮循环中记录当前层的节点数量。
vector<vector<int>> levelOrderGroup(TreeNode* root) {
vector<vector<int>> result;
if (!root) return result;
<pre class='brush:php;toolbar:false;'>queue<TreeNode*> q;
q.push(root);
while (!q.empty()) {
int levelSize = q.size(); // 当前层的节点数
vector<int> currentLevel;
for (int i = 0; i < levelSize; ++i) {
TreeNode* node = q.front();
q.pop();
currentLevel.push_back(node->val);
if (node->left) q.push(node->left);
if (node->right) q.push(node->right);
}
result.push_back(currentLevel);
}
return result;}
基本上就这些。利用队列的先进先出特性,可以自然地实现从上到下、从左到右的访问顺序。这种方法时间复杂度为 O(n),空间复杂度最坏为 O(w),其中 w 是树的最大宽度。
以上就是c++++中如何实现二叉树层序遍历_c++二叉树层序遍历实现方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号