马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
×
以下是使用C++实现的二叉树前序、中序和后序遍历的递归方法示例:- #include <iostream>
- using namespace std;
- // 二叉树节点结构体
- struct TreeNode {
- int val;
- TreeNode* left;
- TreeNode* right;
- TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
- };
- // 前序遍历
- void preOrder(TreeNode* root) {
- if (root == nullptr) return;
- cout << root->val << " ";
- preOrder(root->left);
- preOrder(root->right);
- }
- // 中序遍历
- void inOrder(TreeNode* root) {
- if (root == nullptr) return;
- inOrder(root->left);
- cout << root->val << " ";
- inOrder(root->right);
- }
- // 后序遍历
- void postOrder(TreeNode* root) {
- if (root == nullptr) return;
- postOrder(root->left);
- postOrder(root->right);
- cout << root->val << " ";
- }
- int main() {
- // 构建示例二叉树
- // 1
- // / \
- // 2 3
- // / \ /
- // 4 5 6
- TreeNode* root = new TreeNode(1);
- root->left = new TreeNode(2);
- root->right = new TreeNode(3);
- root->left->left = new TreeNode(4);
- root->left->right = new TreeNode(5);
- root->right->left = new TreeNode(6);
- // 输出遍历结果
- cout << "前序遍历: ";
- preOrder(root);
- cout << endl;
- cout << "中序遍历: ";
- inOrder(root);
- cout << endl;
- cout << "后序遍历: ";
- postOrder(root);
- cout << endl;
- // 释放内存(简单示例中省略,实际使用时应注意内存管理)
- return 0;
- }
复制代码 输出效果:- 前序遍历: 1 2 4 5 3 6
- 中序遍历: 4 2 5 1 6 3
- 后序遍历: 4 5 2 6 3 1
复制代码 代码阐明:
- 二叉树结构界说:使用TreeNode结构体表现二叉树的节点,包罗值val和左右子节点指针。
- 递归遍历函数:
- 前序遍历:先访问根节点,然后递归遍历左子树,末了递归遍历右子树。
- 中序遍历:先递归遍历左子树,然后访问根节点,末了递归遍历右子树。
- 后序遍历:先递归遍历左子树,然后递归遍历右子树,末了访问根节点。
- 示例二叉树的构建:手动创建了一个包罗6个节点的二叉树,用于演示遍历效果。
- 内存管理:示例中未显式开释内存,实际应用中应根据必要添加delete使用。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |