From dd1f714d27cbe27f59b05bd6913b08a058d57244 Mon Sep 17 00:00:00 2001 From: r-u-d-r-a-a <98966726+r-u-d-r-a-a@users.noreply.github.com> Date: Mon, 7 Feb 2022 14:59:02 +0530 Subject: [PATCH] Inorder, Preorder, Postorder Tree Traversals --- cpp/algorithms/tree-traversals.cpp | 84 ++++++++++++++++++++++++++++++ 1 file changed, 84 insertions(+) create mode 100644 cpp/algorithms/tree-traversals.cpp diff --git a/cpp/algorithms/tree-traversals.cpp b/cpp/algorithms/tree-traversals.cpp new file mode 100644 index 000000000..431a0c278 --- /dev/null +++ b/cpp/algorithms/tree-traversals.cpp @@ -0,0 +1,84 @@ +#include +using namespace std; + +struct Node { + int data; + struct Node *left, *right; +}; + + +Node* newNode(int data) +{ + Node* temp = new Node; + temp->data = data; + temp->left = temp->right = NULL; + return temp; +} + +void printPostorder(struct Node* node) +{ + if (node == NULL) + return; + + + printPostorder(node->left); + + + printPostorder(node->right); + + + cout << node->data << " "; +} + + +void printInorder(struct Node* node) +{ + if (node == NULL) + return; + + + printInorder(node->left); + + + cout << node->data << " "; + + + printInorder(node->right); +} + + +void printPreorder(struct Node* node) +{ + if (node == NULL) + return; + + + cout << node->data << " "; + + + printPreorder(node->left); + + + printPreorder(node->right); +} + + +int main() +{ + struct Node* root = newNode(1); + root->left = newNode(2); + root->right = newNode(3); + root->left->left = newNode(4); + root->left->right = newNode(5); + + cout << "\nPreorder traversal of binary tree is \n"; + printPreorder(root); + + cout << "\nInorder traversal of binary tree is \n"; + printInorder(root); + + cout << "\nPostorder traversal of binary tree is \n"; + printPostorder(root); + + return 0; +}