中序排序是二叉树遍历的一种,按照左子树-根节点-右子树的顺序遍历二叉树节点。以下是C++实现中序排序的代码:

#include <iostream>
using namespace std;

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

void inorderTraversal(TreeNode* root) {
    if (root == nullptr) {
        return;
    }
    inorderTraversal(root->left);
    cout << root->val << " ";
    inorderTraversal(root->right);
}

int main() {
    /*
    *       1
    *      / \
    *     2   3
    *    / \
    *   4   5
    */
    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);

    cout << "Inorder traversal:\n";
    inorderTraversal(root);
    cout << endl;

    return 0;
}

输出:

Inorder traversal:
4 2 5 1 3

这里我们创建了一个二叉树,然后调用inorderTraversal函数进行中序排序。函数的实现采用递归的方式,首先遍历左子树,然后输出根节点,最后遍历右子树。在遍历过程中,如果当前节点为空,则直接返回。

c++实现中序排序

原文地址: https://www.cveoy.top/t/topic/bsSH 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录