c++实现中序排序
中序排序是二叉树遍历的一种,按照左子树-根节点-右子树的顺序遍历二叉树节点。以下是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函数进行中序排序。函数的实现采用递归的方式,首先遍历左子树,然后输出根节点,最后遍历右子树。在遍历过程中,如果当前节点为空,则直接返回。
原文地址: https://www.cveoy.top/t/topic/bsSH 著作权归作者所有。请勿转载和采集!