逐层打印二叉树
Posted buctyk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了逐层打印二叉树相关的知识,希望对你有一定的参考价值。
struct BinaryTreeNode {
int nvalue=0;
BinaryTreeNode* pleft = nullptr;
BinaryTreeNode* pright = nullptr;
BinaryTreeNode* parent = nullptr;
};
vector<vector<int>> BinaryTreePrint(BinaryTreeNode* node) { vector<vector<int>> ans; if (node == nullptr) { throw exception("Invalid Input"); return ans; } queue<BinaryTreeNode*>q; q.push(node); while (!q.empty()) { int low = 0, high = q.size(); vector<int>v; while (low++ < high) { BinaryTreeNode* temp = q.front(); v.push_back(temp->nvalue); q.pop(); if (temp->pleft) { q.push(temp->pleft); } if (temp->pright) { q.push(temp->pright); } } ans.push_back(v); } return ans; }
以上是关于逐层打印二叉树的主要内容,如果未能解决你的问题,请参考以下文章
[每日算法0519] 二叉树逐层遍历和通过中序前序获取完整的树
[每日算法0519] 二叉树逐层遍历和通过中序前序获取完整的树
[每日算法0519] 二叉树逐层遍历和通过中序前序获取完整的树