Preorder Tree Traversal

Dear Sciaku Learner you are not logged in or not enrolled in this course.

Please Click on login or enroll now button.

If you have any query feel free to chat us!

Happy Coding! Happy Learning!

Lecture 283:- Preorder Tree Traversal

Preorder tree traversal is a depth-first traversal method in which the nodes are visited in the order: Root -> Left -> Right. Here's a C++ implementation of preorder traversal for a binary tree:

cppCopy code

#include <iostream> struct Node {    int data;    Node* left;    Node* right;    Node(int val) {        data = val;        left = nullptr;        right = nullptr;    } }; // Preorder Traversal void preorderTraversal(Node* root) {    if (root) {        std::cout << root->data << " ";        preorderTraversal(root->left);        preorderTraversal(root->right);    } } int main() {    // Create a binary tree:    //        1    //       / \    //      2   3    //     / \    //    4   5    Node* root = new Node(1);    root->left = new Node(2);    root->right = new Node(3);    root->left->left = new Node(4);    root->left->right = new Node(5);    // Perform preorder traversal    std::cout << "Preorder Traversal: ";    preorderTraversal(root);    std::cout << std::endl;    // Remember to free the allocated memory after use to avoid memory leaks.    delete root->left->left;    delete root->left->right;    delete root->left;    delete root->right;    delete root;    return 0; }

In this implementation, we define a Node struct to represent the nodes of the binary tree. The preorderTraversal function performs the preorder traversal by printing the data of the current node, then recursively calling the function for the left subtree, and finally for the right subtree.

Output:

yamlCopy code

Preorder Traversal: 1 2 4 5 3

The output shows the nodes visited in the preorder traversal order: 1 -> 2 -> 4 -> 5 -> 3.

14. Trees

0 Comments

Start the conversation!

Be the first to share your thoughts

Frequently Asked Questions About Sciaku Courses & Services

Quick answers to common questions about our courses, quizzes, and learning platform

Didn't find what you're looking for?

help_center Contact Support